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SECTION 1 GENERAL DESCRIPTION 


The MC68HC0O5BD7 HCMOS microcontroller is a member of the M68HC05 Family of low- 
cost single-chip microcontrollers. It is particularly suitable as multi-sync computer monitor 
controller. This 8-bit microcontroller unit (MCU) contains an on-chip oscillator, CPU, RAM, 
ROM, DDC12AB module, parallel I/O, Pulse Width Modulator, Multi-Function Timer, 6-bit 
ADC, and SYNC Processor. 


1.1 Features 


1.1.1 Hardware Features 
¢ HCO05 Core 
¢ Low cost, HCMOS technology 
¢ 40-pin DIP and 42-pin SDIP packages 
¢ 256 Bytes of RAM for HCO5BD2 
* 384 Bytes of RAM for HCOSBD7HC705BD7 
¢ 5.75K-Bytes of User ROM for HCO5BD2 
¢ 11.75K-Bytes of User ROM for HCO5BD7 
¢ 11.5K-Bytes of User EPROM for HC705BD7 


¢ 26 Bidirectional I/O lines: 14 dedicated and 12 multiplexed I/O lines. 4 of 
the 14 dedicated I/O lines and 6 of the 12 multiplexed I/O lines have max. 
+12V or +5V open-drain output buffers 


* 16 x 8-bit PWM channels: Two 8-bit PWM channels have +12V open- 
drain outputs: 8 dedicated 8-bit PWM channels have +5V open-drain 
output options 

¢ 6-bit ADC with 4 selectable input channels 

¢ Multi-Function Timer (MFT) with Periodic Interrupt 

¢ Sync Signal Processor module for processing horizontal, vertical, 
composite, and SOG SYNC signals; frequency counting; polarity 


detection; polarity controlled HSYNO and VSYNO or extracted VSYNC 
outputs, and CLAMP pulse output 


* DDC12ABT module contains DDC1 hardware and multi-master I@Ctt 
hardware for DDC2AB protocol 


* Software maskable Edge-Sensitive or Edge and Level-Sensitive External 
Interrupt 


TDDC is a standard defined by VESA. 
tt|?C-bus is a proprietary Philips interface bus. 
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¢« COP watchdog Reset 
¢ Power-On Reset 
¢ Power Saving WAIT Mode; STOP Mode not implemented 
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1.1.2 Software Features 
¢ Similar to MC6800 
* 8X8 unsigned multiply instruction 
¢ Efficient use of program space 
¢ Versatile interrupt handling 
* Software programmable external interrupt options 
¢ True bit manipulation 
¢ Addressing modes with indexed addressing for tables 
¢ Efficient instruction set 
¢ Memory mapped I/O 
¢ Upward software compatible with the MC146805 CMOS family 
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PWMOo** 
PWM1** 
Pulse PWMo2** 
EXTAL XTAL ) Width 


Modulation PWM3** 
(PWM) 


OSCILLATOR 
AND DIVIDE 
BY 2 


PWM4** 


PWM5** 
PWM6** 


PWM7** 


68HC05 CPU 


ACCUM DDC12AB 


CPU REGISTERS 
INDEX REG 


STK PTR PDO*/SDA* 
DATA Pont a SPDT RCL" 
PROGRAM COUNTER DIR 

REG REG ; 


PD2***/CLAMP 
PD3*/SOG 


COND CODE REG 1H} TIN|Z/C’ 


PCO*/PWM8* 
<_— 

PC1*/PWM9* 
<> 

PC2/PWM10/ADCO 
<_< 

PC3/PWM11/ADC1 
<> 


PC4/PWM12/ADC2 5.75K-bytes ROM for RAM SYNC 
<> 


HCO5BD2 PROCESSOR 


11.75K-bytes ROM 256 bytes for HCOS5BD2 
for HCO5BD7 384 bytes for HCO5BD7 

11.5K-bytes EPROM 384 bytes for HC705BD7 
for HC705BD7 


PC5/PWM13/ADC3 
<< 


PC6/PWM14/VSYNO 
<_— 

PC7/PWM15/HSYNO 
_ 


PWM/ADC/HVPROCESSOR 


***: +5V open-drain 

**: +5V open-drain option 

*: +12V open-drain 

IRQ/VPP: VPP valid for HC705 version only, not used for HC05 version 


Figure 1-1: MC68HCO5BD7 Block Diagram 
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PWM2** 1 ee 40? VSYNC 
PWM1** 2 [39|<t—— HSYNC 
PWMo** rs [38h-—|_ = PWM3** 
RESET za [37+ 1 PwmMa* 
VDD GB 36+» + PWM5** 
vss 6 -35--— | PWM6** 
XTAL Z -34}——> PWM7™ 
EXTAL 8 [33 }<t—> PC7/PWM15/HSYNO 
PB5* =n -32}—<—p PC6/PWM14/VSYNO 
PB4* 10 MC68HC05BD7 | 31 }<— =PC5/PWM13/ADC3 
PB3* if (30}—<<—p PC4/PWM12/ADC2 
PB2* iv Ee 59 }<—p> © PC3/PWM11/ADC1 
PB1 iki [28 \<t—t> PC2/PWM10/ADCO 
PBO mes [ 27\—<t— PC1*/PWM9* 
IRQ/VPP —— 15] [ 26/t—> + PCO*/PWMS8* 
PA7 ~<¢— 16! [25|<— PD1*/SCL* 
PAG 1Z [24]}<t— PDO0*/SDA* 
PA5 18] [23}——t PAO 
PA4 19 [22 \~—s PAI 
PA3 20 [DT <'—e PA2 


**: +5V open-drain option 
*: +12V open-drain 
IRQ/VPP: VPP valid for HC705 version only, not used for HC05 version 


Figure 1-2: MC68HCO5BD7/BD2 40-Pin DIP Pin Assignment 
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PWM2** 
PWM1** 
PWMo0** 
RESET 
VDD 
PD3*/SOG 
vss 


PA3 


***: +5V open-drain option 
**: +5V open-drain option 


ae 


MC68HC05BD7 


42-PIN SDIP 


42 |<—__ 
4 }<?—— 


*: +12V open-drain 
IRQ/VPP: VPP valid for HC705 version only, not used for HC05 version 


VSYNC 

HSYNC 

PWM3** 

PWM4** 

PWM5** 
PD2***/CLAMP 
PWM6** 

PWM7** 
PC7/PWM15/HSYNO 
PC6/PWM14/VSYNO 
PC5/PWM13/ADC3 
PC4/PWM12/ADC2 
PC3/PWM11/ADC1 
PC2/PWM10/ADCO 
PC1*/PWM9* 
PCO*/PWM8* 
PD1*/SCL* 
PDO*/SDA* 

PAO 

PA1 

PA2 


Figure 1-3: MC68HCO5BD7/BD2 42-Pin SDIP Pin Assignment 


Page 6 


SECTION 1: GENERAL DESCRIPTION 


For More Information On This Product, 


Go to: www.freescale.com 


VIL6SHUUSBL/ KevFre@escale Semicondugternsalng case SPEUIFICGALION 


1.2 Signal Description 


1.2.1 VDD and VSS 
VDD is the positive supply pin and VSS is the ground pin. 


1.2.2 IRQ/VPP 


This pin has two functions. While in user mode, this pin serves as IRQ, a general purpose 
interrupt input which is software programmable for two choices of interrupt triggering 
sensitivity. These options are: 1) negative edge-sensitive triggering only, or 2) both 
negative edge-sensitive and level-sensitive triggering. In the latter case, either type of input 
to the IRQ pin will produce the interrupt. This interrupt can be inhibited by setting the 
INHIRQ bit in the MFT register. While in bootstrap mode, this pin is used as VPP pin for 
HC705 version. It is used to supply high voltage needed for programming the user EPROM. 


1.2.3 EXTAL, XTAL 


The EXTAL and XTAL pins are the connections for the on-chip oscillator. The EXTAL, and 
XTAL pins can accept the following sets of components: 


1. Acrystal as shown in Figure 1-4(a) 
2. An external clock signal as shown in Figure 1-4(b) 


The frequency, fogc, of the oscillator or external clock source is divided by two to produce 
the internal operating frequency, fop. 


1.2.3.1 Crystal Oscillator 


The circuit in shows Figure 1-4(a) a typical oscillator circuit for an AT-cut, parallel resonant 
crystal. The crystal manufacturer’s recommendations should be followed, as the crystal 
parameters determine the external component values required to provide maximum 
stability and reliable start-up. The load capacitance values used in the oscillator circuit 
design should include all stray capacitances. The crystal and components should be 
mounted as close as possible to the pins for start-up stabilization and to minimize output 
distortion. An internal start-up resistor of approximately 2 MQ is provided between 
EXTAL and XTAL for the crystal type oscillator. 


MCU 


EXTAL XTAL 


EXTAL XTAL 


(a) Crystal or unconnected 


-—j- Ceramic Resonator Spain 
a =~ Connections 
oO oA Connection 


External Clock 


Figure 1-4: Oscillator Connections 
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1.2.4 RESET 


This active low input-only pin is used to reset the MCU to a known start-up state. The 
RESET pin contains an internal Schmitt trigger as part of its input to improve noise 
immunity. See SECTION 5 for more details. 


1.2.5 PAO-PA7 


These eight I/O lines comprise Port A. The state of any pin is software programmable and 
all Port A lines are configured as inputs during Reset. See SECTION 7 for a detailed 
description of I/O programming. 


1.2.6 PBO-PB5 


These six I/O lines comprise Port B. The state of any pin is software programmable and all 
Port B lines are configured as inputs during Reset. PB2 to PB5 are +12V open-drain pins. 
See SECTION 7 for a detailed description of I/O programming. 


1.2.7 PC0*/PWM8*-PC1*/PWM9* 


These two +12V open-drain pins are either 8-bit PWM channels 8 to 9 outputs or general 
purpose I/O port C. The state of any pin is software programmable and all Port C lines are 
configured as inputs during Reset. See SECTION 7 for a detailed description of I/O 
programming. 


1.2.8 PC2/PWM10/ADCO- PC5/PWM13/ADC3 


These four pins can be selected as general purpose I/O of port C, PWM or ADC input 
channel 0-2. See SECTION 7 for how to configure the pins. Also see SECTION 8 and 
SECTION 12 for a detailed description of these modules. 


1.2.9 PC6/PWM14/VSYNO, PC7/PWM15/HSYNO 


These two pins can be selected as general purpose I/O of port C, PWM or sync signal 
outputs. See SECTION 7 for how to configure the pins. Also see SECTION 8 and SECTION 
10 for a detailed description of these modules. 


1.2.10 PD0*/SDA*, PD1*/SCL* 


These pins are either general purpose |I/O pins of port D or the data line (SDA) and clock 
line (SCL) of DDC12AB. These two pins are open-drain pins. See SECTION 7 for how to 
configure the pins. See SECTION 9 for a detailed description. 


1.2.11. PD2***/CLAMP, PD3*/SOG 


The PD2*** is +5V open-drain general purpose I/O pin and the PD3* is +12V open-drain 
general purpose I/O pin. The PD2 pin could become the CLAMP pulse push-pull output to 
Pre-AMP IC and the PD3 pin could become the SOG digital input of the Sync Processor 
when the corresponding enable bit in SPIOCR register is set. These two pins will not be 
bonded out in 40-pin DIP package. 
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1.2.12 ©PWM0**-PWM7** 


These pins are dedicated for 8-bit PWM channels 0 to 7, which have +5V open-drain 
software options. See SECTION 8 for a detailed description. 


1.2.13 HSYNC, VSYNC 


These two input pins are for video sync signals input from the host computer. The signals 
will be used for video mode detection and output to HSYNO and VSYNO. The host 
computer can also send a composite sync signal to the HSYNC input. This composite 
signal will be separated internally. The polarity of the input signals can be either positive or 
negative. These two pins contain internal Schmitt triggers as part of their inputs to improve 
noise immunity. See SECTION 10 for a detail description. 


1.3 Options 


MC68HCO5BD7 provides an option for IRQ interrupt edge only sensitivity or edge and level 
sensitivity and one option register for individual PWM channels 0 to 7 to be programmed 
as open-drain type output. The IRQ option is selected by setting the appropriate bit in the 
MFTCSR register at address $0008 and the PWM open-drain option register is located at 
address $0012. 


SECTION 1: GENERAL DESCRIPTION 


For More Information On This Product, 
Go to: www.freescale.com 


Page 9 


GENEHAL RELEASE spveesecale Semiconductor, WG6sHUU5BU/ Hev. z.U 


SECTION 1: GENERAL DESCRIPTION 
Page 10 


For More Information On This Product, 
Go to: www.freescale.com 


VIUL6SHUUSBL/ KevF¥r@eescale Semicondugeternslng cast SPEUIFICGALION 


SECTION 2 


MEMORY 


The MC68HCO5BD7 has a 16K byte memory map, consisting of user ROM/EPROM, RAM, 


Self-Check/Bootstrap ROM, and I/O as shown in Figure 2-1. 


$0000 


$0030 


$00C0 | 


Stack 
RAM 64 Bytes 
i 256 Bytes for HCO5BD2, = 


$0100 


$01B0 


$0E00 


$0FEO 


$1000 


$2800 


$3E00 
$3F00 


$3FE0 


$3FFO 
$3FFF 


/O 
48 Bytes 


384 Bytes for HCOS5BD7/HC705BD7 


Unused 


480 Bytes Bootstrap ROM for HC705BD7 
Unused in HCO5BD2/HCO5BD7 


User ROM 
5.57K-bytes for HCO5BD2 
aie 11.75K-bytes for HCO5BD7 
User EPROM 
11.5K-bytes for HC705BD7 


Unused in HC705BD7 


224 Bytes Self-Check ROM for HCO5BD2/HCO5BD7 


Self-Check/Bootstrap Vectors 16 Bytes 
User Vectors 16 Bytes 


Figure 2-1: The 16K Memory Map of the MC68HCO5BD7 
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READ 


ADDR REGISTER Ware. <2 6 5 4 3 2 1 0 
PORT A DATA R 
$0000] Bota - PAZ PAG PA5 PA PA3 PA2 PAt PAO 
PORT B DATA R 
$0001} porta 7 PB5 PB4 PB3 PB2 PBt PBO 
R 
$0002 se clay pc7 | pce | pcs | pc4 | pcs | pce | pci | Pco 
w 
PORT D DATA R 
jet PD PD2 PD1 PD 
$0003} EOprp 7 3 0 
R 
$0004 Be a 7 DDRA7 | DDRAG | DDRAS | DDRA4 | DDRA3 | DDRA2 | DDRA1 | DDRAO 
R 
$0006, COREE OAIA DIRECTION — DDRB5 | DDRB4 | DDRB3 | DDRB2 | DDRB1 | DDRBO 
DDRB W 
R 
$0006 poe oe 7 DDRC7 | DDRC6 | DDRC5 | DDRC4 | DDRC3 | DDRC2 | DDRC1 | DDRCO 
R 
0007) Loo) 2D PATA DIRECTION DDRD3 | DDRD2 | DDRD1 | DDRDO 
DDRD W 
R 
$0008] MFT CTRL/STATUS REG TOF | RTIF | TOFIE | RTIE | IRQN | INHIRQ| RTI RTO 
METCSR W 
so009| MET TIMER COUNTER REG R |METCR7|METCR6 |METCRS5 |MFTCR4 |MFTCR3 |MFTCR2 |MFTCR1 |MFTCRO 
METCR W 
R 
$000A Nae BEG! wy PMS | PwMt14 | PwM1s | PWMi2 | PWM11 | PWM10 | PWM9 | PWMs 
R 
$000B oe REGS HSYNO| VSYNO| aADc3 | ADC2 | ADC1 | ADCO | SCL | SDA 
w 
R VSIF 
SP CONTROL & STATUS | | VSIE | VEDGE COMP | VINVO | HINVO MEO! POE 
$000C 
SPCSR Ww 
s000D VERT FREQUENCY HIGH REG R VOF 0 0 VF12 VF11 VF10 VF9 VF8& 
VFHR W 
sooog| VERT FREQUENCY LOW REG R| VF7 VE6 VE5 VF4 VE3 VF2 VF1 VEO 
VFLR Ww 
sooor | HOR FREQUENCY HIGH REG R| HOVER] HFH6 | HFH5 | HFH4 | HFH3 | HFH2 | HFH1 | HFHO 
HFHR Ww 
N 
UNIMPLEMENTED RESERVED NAN 
Figure 2-2: MC68HCO5BD7 I/O Register $00-$0F 
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READ 
ADDR REGISTER Write 2? 6 5 4 3 2 1 0 
$0010 HOR FREQUENCY LOW REG R 0 0 0 HFL4 HFL3 HFL2 HFL1 HFLO 
HFLR W 
P IO CONTROL RE R |VSYNCS|HSYNCS NY) 
OMe COINV SOGIN | CLAMP |] BPOR | SOUT 
SPIOCR WW \ 
R 
$0012 | PWM OPEN-DRAIN OPTION 7PWMO | 6PWMO | 5PWMO| 4PWMO | 3PWMO] 2PWMO | 1PWMO | OPWMO 
REGISTER Ww 
$0013| UNIMPLEMENTED R 
Ww 
R | RESULT 
$0014 | ADC CONTROL/STATUS REG aps | ap4 | ap3 | ap2 | Api | ado 
w 
$0015 | ADC CHANNEL REGISTER R CHSL1 | CHSLO 
Ww 
R 
gooig | DDC MASTER CONTROL REG ALIE | NAKIF| BB | mast | mRW | BR2 | BRt | BRO 
DMCR W 
R 
$0017! ee eee HESS REGISTER pap7 | paps | paps | pap4 | DADs | DAD2 | DADI | EXTAD 
DADR W 
R 
$001g | DDC CONTROL REGISTER DEN | DIEN TXAK | SCLIEN |DDC1EN 
DCR Ww 
| 
so01g| DDC STATUS REGISTER R| RXIF | TXIF |MATCH] RW | RXAK | SCLIF | TXBE | RXBF 
DSR Ww 
goo1a| DDC DATA TRANSMIT REG R) ptp7 | ptps | ptps | ptp4 | ptp3 | ptp2 | ptp1 | pTDo 
DDTR W 
DDC DATA RECEIVE REG R| DRD7| DRD6| DRDS5| DRD4|} DRD3|} DRD2| DRD1| DRDO 
$001B} DpRR 
w 
s001¢| UNIMPLEMENTED R 
w 
$001p| RESERVED FOR EPROM R Sige teeth 
CONTROL PCR wh 
g001e| UNIMPLEMENTED R 
Ww 
$001F RESERVED R 
w 
UNIMPLEMENTED RESERVED NNW) 


Figure 2-3: MC68HCO5BD7 I/O Register $10-$1F 
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READ 
ADDR REGISTER WRITE 


PULSE WIDTH MODULATO 
$0020] gpwn 


R R 
7 OPWM4 | OPWM3 |} OPWM2 | OPWM1 | OPWMO} OBRM2 | OBRM1 | OBRMO 


PULSE WIDTH MODULATOR R 
$0021 1PWM a 1PWM4 | 1PWM3 |} 1PWM2 |} 1PWM1} 1PWMO} 1BRM2 |} 1BRM1 | 1BRMO 


PULSE WIDTH MODULATOR 
2PWM 


PULSE WIDTH MODULATOR 
3PWM 


R 
Ww 
R 
Ww 
PULSE WIDTH MODULATOR R 
Ww 
R 
Ww 
R 


4PWM 


PULSE WIDTH MODULATOR 
SPWM 


PULSE WIDTH MODULATOR 
$0026 6PWM a 6PWM4 | 6BPWM3 | 6PWM2| 6PWM1 | 6PWMO| 6BRM2 | 6BRM1 | 6BRMO 


PULSE WIDTH MODULATOR 
7PWM 


PULSE WIDTH MODULATOR 
8PWM 


PULSE WIDTH MODULATOR 
9PWM Q9PWM4 | 9PWM3 | 9PWM2| 9PWM1 | 9PWMO| 9BRM2 | 9BRM1 


PULSE WIDTH MODULATOR 
10PWM 10PWM4! 10PWM3} 10PWM2| 10PWM1) 10PWMO} 10BRM2| 10BRM1 


PULSE WIDTH MODULATOR 
11PWM 11PWM4! 11PWM3} 11PWMe2) 11PWM1)11PWMO} 11BRM2| 11BRM1 


PULSE WIDTH MODULATOR 
12PWM 12PWM4! 12PWM3} 12PWM2) 12PWM1) 12PWMO} 12BRM2| 12BRM1 


PULSE WIDTH MODULATOR 
13PWM 13PWM4! 13PWM3} 13PWM2| 13PWM1) 13PWMO] 13BRM2| 13BRM1 


PULSE WIDTH MODULATOR 


14PWM 14PWM4! 14PWM3} 14PWM2| 14PWM1) 14PWMO} 14BRM2| 14BRM1 


PULSE WIDTH MODULATOR 
15PWM 


15PWM4! 15PWM3} 15PWM2| 15PWM1) 15PWMO} 15BRM2| 15BRM1 


UNIMPLEMENTED RESERVED WANN) 


Figure 2-4: MC68HCO5BD7 I/O Register $20-$2F 
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2.1 COP 


The COP time-out is prevented by writing a ‘0’ to bit 0 of address $3FFO. See SECTION 11 
for detail. 


2.2 ROM 


For MC68HCO5BD7, the user ROM consists of 11.75K bytes of ROM from $1000 through 
$3EFF and 16 bytes of user vectors from $3FFO through $3FFF. For MC68HCOS5BD2, the 
user ROM consists of 5.75K bytes of ROM from $2800 through $3EFF and 16 bytes of user 
vectors from $3FFO through $3FFF. The Self-Check ROM is located from $3F00 through 
$3FE0 and Self-Check vectors are located from $3FEO through $3FEF. 


2.3 EPROM 


For MC68HC705BD7, the user EPROM consists of 11.5K bytes of EPROM from $1000 
through $3DFF and 16 bytes of user vectors from $3FFO through $3FFF. The Bootstrap 
ROM is located from $0E00 through $0FDF and Bootstrap vectors are located from $3FE0 
through $3FEF, at the same location as Self-Check vectors. 


2.4 RAM 


The user RAM consists of 384 bytes from $0030 to $01AF for HCO5BD7/HC705BD7. User 
RAM consists of 256 bytes from $30 to $12F for HCOS5BD2. The stack pointer can access 
64 bytes of RAM from $00FF to $00CO. See Section 3.1.3, Stack Pointer (SP). 


NOTE: Using the stack area for data storage or temporary work locations requires 
care to prevent it from being overwritten due to stacking from an interrupt 
or subroutine call. 
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SECTION 3 CPU CORE 


The MC68HCO5BD7 has a 16K memory map. Therefore it uses only the lower 14 bits of 
the address bus. In the following discussion the upper 2 bits of the address bus can be 
ignored. The stack has only 64 bytes. Therefore, the stack pointer has been reduced to only 
6 bits and will only decrement down to $00CO and then wrap-around to $00FF. All other 
instructions and registers behave as described in this chapter. 


3.1 Registers 


The MCU contains five registers which are hard-wired within the CPU and are not part of 
the memory map. These five registers are shown in Figure 3-1 and are described in the 
following paragraphs. 


7 6 5 4 3 2 1 0 
T T T T T T T 
ACCUMULATOR A 
T T T T T T T 
INDEX REGISTER X 
15 14 13 #12 #11 #10 9 8 
T T T T T T T 
0 0 0 0 0 0 0 0 1 1 STACK POINTER SP 
T T T T T T T T T T T T T T T 
PROGRAM COUNTER PC 
T T T T 
CONDITION CODE REGISTER 1 1 1 H | N Z Cc cc 


HALF-CARRY BIT (FROM BIT 3) at 
INTERRUPT MASK 
NEGATIVE BIT 


ZERO BIT 
CARRY BIT 


Figure 3-1: MC68HC05 Programming Model 
3.1.1 Accumulator (A) 


The accumulator is a general purpose 8-bit register as shown in Figure 3-1. The CPU uses 
the accumulator to hold operands and results of arithmetic calculations or non-arithmetic 
operations. The accumulator is not affected by a reset of the device. 
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3.1.2 Index Register (X) 


The index register shown in Figure 3-1 is an 8-bit register that can perform two functions: 
¢ Indexed addressing 
¢ Temporary storage 


In indexed addressing with no offset, the index register contains the low byte of the operand 
address, and the high byte is assumed to be $00. In indexed addressing with an 8-bit offset, 
the CPU finds the operand address by adding the index register content to an 8-bit 
immediate value. In indexed addressing with a 16-bit offset, the CPU finds the operand 
address by adding the index register content to a 16-bit immediate value. 


The index register can also serve as an auxiliary accumulator for temporary storage. The 
index register is not affected by a reset of the device. 


3.1.3 Stack Pointer (SP) 


The stack pointer shown in Figure 3-1 is a 16-bit register. In MCU devices with memory 
space less than 64K bytes the unimplemented upper address lines are ignored. The stack 
pointer contains the address of the next free location on the stack. During a reset or the 
reset stack pointer (RSP) instruction, the stack pointer is set to $00FF. The stack pointer is 
then decremented as data is pushed onto the stack and incremented as data is pulled off 
the stack. 


When accessing memory, the ten most significant bits are permanently set to 0000000011. 
The six least significant register bits are appended to these ten fixed bits to produce an 
address within the range of $00FF to $00CO. Subroutines and interrupts may use up to 64 
($40) locations. If 64 locations are exceeded, the stack pointer wraps around and 
overwrites the previously stored information. A subroutine call occupies two locations on 
the stack and an interrupt uses five locations. 


3.1.4 Program Counter (PC) 


The program counter shown in Figure 3-1 is a 16-bit register. In MCU devices with memory 
space less than 64K bytes the unimplemented upper address lines are ignored. The 
program counter contains the address of the next instruction or operand to be fetched. 


Normally, the address in the program counter increments to the next sequential memory 
location every time an instruction or operand is fetched. Jump, branch, and interrupt 
operations load the program counter with an address other than that of the next sequential 
location. 


3.1.5 Condition Code Register (CCR) 


The CCR shown in Figure 3-1 is a 5-bit register in which four bits are used to indicate the 
results of the instruction just executed. The fifth bit is the interrupt mask. These bits can be 
individually tested by a program, and specific actions can be taken as a result of their 
states. The condition code register should be thought of as having three additional upper 
bits that are always ones. Only the interrupt mask is affected by a reset of the device. The 
following paragraphs explain the functions of the lower five bits of the condition code 
register. 
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3.1.5.1 Half Carry Bit (H-Bit) 


When the half-carry bit is set, it means that a carry occurred between bits 3 and 4 of the 
accumulator during the last ADD or ADC (add with carry) operation. The half-carry bit is 
required for binary-coded decimal (BCD) arithmetic operations. 


3.1.5.2 Interrupt Mask (I-Bit) 


When the interrupt mask is set, the internal and external interrupts are disabled. Interrupts 
are enabled when the interrupt mask is cleared. When an interrupt occurs, the interrupt 
mask is automatically set after the CPU registers are saved on the stack, but before the 
interrupt vector is fetched. If an interrupt request occurs while the interrupt mask is set, the 
interrupt request is latched. Normally, the interrupt is processed as soon as the interrupt 
mask is cleared. 


A return from interrupt (RTI) instruction pulls the CPU registers from the stack, restoring the 
interrupt mask to its state before the interrupt was encountered. After any reset, the 
interrupt mask is set and can only be cleared by the Clear I-Bit (CLI), or WAIT instructions. 


3.1.5.3 Negative Bit (N-Bit) 


The negative bit is set when the result of the last arithmetic operation, logical operation, or 
data manipulation was negative. (Bit 7 of the result was a logical one.) 


The negative bit can also be used to check an often tested flag by assigning the flag to bit 
7 of a register or memory location. Loading the accumulator with the contents of that 
register or location then sets or clears the negative bit according to the state of the flag. 


3.1.5.4 Zero Bit (Z-Bit) 


The zero bit is set when the result of the last arithmetic operation, logical operation, data 
manipulation, or data load operation was zero. 


3: 1.5.5 Carry/Borrow Bit (C-Bit) 


The carry/borrow bit is set when a carry out of bit 7 of the accumulator occurred during the 
last arithmetic operation, logical operation, or data manipulation. The carry/borrow bit is 
also set or cleared during bit test and branch instructions and during shifts and rotates. This 
bit is neither set by an INC nor by a DEC instruction. 
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SECTION 4 INTERRUPTS 


4.1 CPU Interrupt Processing 


Interrupts cause the processor to save register contents on the stack and to set the interrupt 
mask (I-bit) to prevent additional interrupts. Unlike RESET, hardware interrupts do not 
cause the current instruction execution to be halted, but are considered pending until the 
current instruction is complete. 


If interrupts are not masked (I-bit in the CCR is cleared) and the corresponding interrupt 
enable bit is set the processor will proceed with interrupt processing. Otherwise, the next 
instruction is fetched and executed. If an interrupt occurs the processor completes the 
current instruction, then stacks the current CPU register states, sets the I-bit to inhibit 
further interrupts, and finally checks the pending hardware interrupts. If more than one 
interrupt is pending following the stacking operation, the interrupt with the highest vector 
location shown in Table 4-1 will be serviced first. The SWI is executed the same as any 
other instruction, regardless of the I-bit state. 


When an interrupt is to be processed the CPU fetches the address of the appropriate 
interrupt software service routine from the vector table at locations $3FFO thru $3FFF as 
defined in Table 4-1. 


Table 4-1: Vector Address for Interrupts and Reset 


Register| Flag Interrupts CPU Int | Vector Adds. 
N/A N/A Reset RESET $3FFE-$3FFF 
N/A N/A Software SWI $3FFC-$3FFD 
N/A N/A External Interrupt IRQ $3FFA-$3FFB 

SPCSR VSIF VSINT SP $3FF8-$3FF9 
DMCR TXIF DDC12AB interrupt DDC12AB $3FF6-$3FF7 
DSR RXIF 
ALIF 
NAKIF 
SCLIF 
MFTCSR TOF Timer Overflow MFT $3FF4-$3FF5 
RTIF Real Time Interrupt 
N/A N/A N/A N/A $3FF2-$3FF3 
N/A N/A N/A N/A $3FFO-$3FF1 


An RII instruction is used to signify when the interrupt software service routine is 
completed. The RTI instruction causes the register contents to be recovered from the stack 
and normal processing to resume at the next instruction that was to be executed when the 
interrupt took place. Figure 4-1 shows the sequence of events that occur during interrupt 
processing. 
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From 
RESET 
nN 
IRQ 
External Clear IRQ 
Interrupt? Latch 
>| 
DDC12AB 
Interrupt? >| 
MFT Yy 
Interrupt? zi >| 
N 
Vv 
PC -> (SP,SP-1) 
>t< X -> (SP-2) 
i A -> (SP-3) 
= - = 
Fetch Next CC -> (SP-4) 
Instruction 
Vv 
Set I-Bit in CCR 
ui Vv 
Load Interrupt 
Vectors to PC 
N 
'< yY 
Y Restore Registers 
| from Stack 
CC, A, X, PC 
N 
Execute 
Instruction I 


Figure 4-1: Interrupt Processing Flowchart 
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4.2 Reset Interrupt Sequence 


The RESET function is not in the strictest sense an interrupt; however, it is acted upon ina 
similar manner. A low level input on the RESET pin or an internally generated reset signal 
causes the program to vector to its starting address which is specified by the contents of 
$3FFE and $3FFF. The I-bit in the condition code register is also set. The MCU is 
configured to a known state during this type of reset as described in SECTION 5. 


4.3 Software Interrupt (SWI) 


The SWI is an executable instruction and a non-maskable interrupt since it is executed 
regardless of the state of the I-bit in the CCR. If the I-bit is zero (interrupts enabled), the 
SWI instruction executes after interrupts which were pending before the SWI was fetched, 
or before interrupts generated after the SWI was fetched. The interrupt service routine 
address is specified by the contents of $3FFC and $3FFD. 


4.4 Hardware Interrupts 


All hardware interrupts except RESET are maskable by the I-bit in the CCR. If the I-bit is 
set, all hardware interrupts (internal and external) are disabled. Clearing the I-bit enables 
the hardware interrupts. There are four types of hardware interrupts which are explained in 
the following sections. 


4.4.1 External Interrupt (IRQ) 


If the IRQ option is edge and level sensitive triggering (IRQN=0), a low level at the IRQ pin 
and a cleared interrupt mask bit of the condition code register will cause an EXTERNAL 
INTERRUPT to occur. If the MCU has finished with the interrupt service routine, but the IRQ 
pin is still low, the EXTERNAL INTERRUPT will start again. In fact, the MCU will keep on 
servicing the EXTERNAL INTERRUPT as long as the IRQ pin is low. If the IRQ pin goes 
low for a while and resumes to high (a negative pulse) before the interrupt mask bit is 
cleared, the MCU will not recognize there was an interrupt request, and no interrupt will 
occur after the interrupt mask bit is cleared. 


If the IRQ option is negative edge sensitive triggering (IRQN=1), a negative edge occurs at 
the IRQ pin and a cleared interrupt mask bit of the condition code register will cause an 
EXTERNAL INTERRUPT to occur. If the MCU has finished with the interrupt service 
routine, but the IRQ pin has not returned back to high, no further interrupt will be generated. 
The interrupt logic recognizes negative edge transitions and pulses (special case of 
negative edges) only. If the negative edge occurs while the interrupt mask bit is set, the 
interrupt signal will be latched, and interrupt will occur as soon as the interrupt mask bit is 
cleared. The latch will be cleared by RESET or cleared automatically during fetch of the 
EXTERNAL INTERRUPT vectors. Therefore, one (and only one) external interrupt edge 
could be latched while the interrupt mask bit is set. If the INHIRQ bit in the MFT register is 
set, no IRQ interrupt can be generated. 


The service routine address is specified by the contents of $3FFA and $3FFB. Figure 4-2 
shows the two methods for the interrupt line (IRQ) to be recognized by the processor. The 
first method is single pulses on the interrupt line spaced far apart enough to be serviced. 
The minimum time between pulses is a function of the number of cycles required to execute 
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the interrupt service routine plus 21 cycles. Once a pulse occurs, the next pulse should not 
occur until the MCU software has exited the routine (an RTI occurs). The second 
configuration shows several interrupt line “wire-ANDed” to perform the interrupts at the 
processor. Thus, if after servicing one interrupt and the interrupt line remains low, then the 
next interrupt is recognized. 


NOTE: — IRQN is located at bit 3 of the Multi-function Timer Register at $0008, and 
is cleared by reset. 


Edge-sensitive Trigger Condition 
IR aa et—th The minimum pulse width tILIH is one 
internal bus period. 
The period tILIL should not be less than the 
<i tub p number of cycles it takes to execute the 
interrupt service routine plus 21 cycles 
IRQ1 <— tun = Level-sensitive Trigger Condition 
If after servicing an interrupt, the IRQ 
e e remains low, then the next interrupt is 
recognized. 
e e 
e e : ; 
Normally used with pull-up resistor for 
Wire-Ored connection 
Ron _ 


Figure 4-2: External Interrupt 


4.4.2 VSYNC Interrupt 


The VSYNC interrupt is generated when a specific edge of VSYNC input is detected as 
described in SECTION 10. The interrupt enable bit, VSIE, for the VSYNC interrupt is 
located at bit 7 of SYNC Processor Control and Status Register (GPCSR) at $000C. The I- 
bit in the CCR must be cleared in order for the VSYNC interrupt to be enabled. This 
interrupt will vector to the interrupt service routine located at the address specified by the 
contents of $3FF8 and $3FF9. The VSYNC Interrupt Flag (VSIF) must be cleared by writing 
0’ to it in the interrupt routine. 


4.4.3 DDC12AB Interrupt 


The DDC12AB interrupt is generated by the DDC12AB circuit as described in SECTION 9. 
The interrupt enable bit for the DDC12AB interrupt is located at bit 6 of DDC12AB Control 
Register (DCR) at $0018. The I-bit in the CCR must be cleared in order for the DDC12AB 
interrupt to be enabled. This interrupt will vector to the interrupt service routine located at 
the address specified by the contents of $3FF6 and $3FF7. 
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4.4.4 Multi-Function Timer Interrupt (MFT) 


There are two different Multi-Function Timer (MFT) interrupt flags that will cause an 
interrupt whenever they are set and enabled. The interrupt flags and enable bits are located 
in the MFT Control and Status Register. Either of these interrupts will vector to the same 
interrupt service routine, located at the address specified by the contents of $3FF4 and 
$3FF5. See Section SECTION 11, MULTI-FUNCTION TIMER for more informations on 
MFT interrupts. 
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SECTION 5 RESETS 


The MCU can be reset from four sources—1 external and 3 internal: 
¢ External RESET pin 
* Power-On-Reset (POR) 
* Computer Operating Properly Watchdog Reset (COPR) 
* Illegal Address Reset (ILADR) 


5.1 External Reset (RESET) 


The RESET pin is the only external reset source. This pin is connected to a Schmitt trigger 
input gate to provide an upper and lower threshold voltage separated by a minimum 
amount of hysteresis. This external reset occurs whenever the RESET pin is pulled below 
the lower threshold and remains in reset until the RESET pin rises above the upper 
threshold. This active low input will generate the RST signal and reset the CPU and 
peripherals. Termination of the external RESET input can alter the operating mode of the 
MCU. 


NOTE: Activation of the RST signal is generally referred to as reset of the device, 
unless otherwise specified. 


5.2 Internal Resets 


The three internally generated resets are the initial power-on reset, the COP Watchdog 
Timer reset, and the illegal address reset 


5.2.1 Power-On Reset (POR) 


The internal POR is generated on power-up to allow the clock oscillator to stabilize. The 
POR is strictly for power-on condition and is not able to detect a drop in the power supply 
voltage (brown-out). There is an oscillator stabilization delay of 4065 internal processor bus 
clock cycles (PH2) after the oscillator becomes active. 


The POR will generate the RST signal which will reset the CPU. If any other reset function 
is active at the end of this 4065 cycles delay, the RST signal will remain in the reset 
condition until the other reset condition(s) end. 


5.2.2 Computer Operating Properly Reset (COPR) 


The internal COPR reset is generated automatically (if enabled) by a time-out of the COP 
Watchdog Timer. This time-out occurs if the counter in the COP Watchdog Timer is not 
reset (cleared) within a specific time by a program reset sequence. Refer to SECTION 11 
for more information on this time-out feature. 
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5.2.3 Illegal Address (ILADR) Reset 


The MCU monitors all opcode fetches. If an illegal address is accessed during an opcode 
fetch, an internal reset is generated. Illegal address space consists of all unused locations 
within the memory space and the I/O registers. (See Figure 2-1 : The 16K Memory Map 
of the MC68HCO5BD7.) Because the internal reset signal is used, the MCU comes out of 
an ILADR Reset in the same operating mode it was in when the opcode was fetched. The 
ILADR Reset is disabled in Test (Non User) Mode. 
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SECTION 6 OPERATING MODES 


The HCO5BD7/HCO5BD2 has the following operating modes: single-chip mode (SCM) and 
self-check mode. 


The HC705BD7 has the following operating modes: User mode and bootstrap mode. 
6.1 User Mode 


In this mode, all address and data bus activity occurs within the MCU so no external pins 
are required for these functions. 


6.2 SELF-CHECK MODE 


In this mode, the reset vector is fetched from the 240-byte internal self-check ROM at 
$3F00:$3FEF. The self-check ROM contains a self-check program to test the functions of 
internal modules. 


6.3 Bootstrap Mode 


In this mode, the reset vector is fetched from the 480-byte internal bootstrap ROM at 
$0E00:$0FDF. The bootstrap ROM contains a small program which reads a program into 
internal RAM and then passes control to execute EPROM programming. 


6.4 Mode Entry 


The mode entry is done at the rising edge of the RESET pin. Once the device enters one 
of the operating modes, the mode can only be changed by an external reset. 


At the rising edge of the RESET pin, the device latches the states of IRQ and PB5 pins and 
places itself in the specified mode. While the RESET pin is low, all pins are configured as 
Single Chip Mode. The following table shows the states of IRQ and PB5 pins for each mode 
entry. 
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Table 6-1: Mode Select Summary 


MODE RESET IRQ PB5 
USER MODE = LorH X 
SELF CHECK/BOOTSTRAP 4 Vist H 


Vier = 1.8 x VDD 


~<q Single __ 

M5 Chip Mode ; H 

RESET d : 
CESS ches hava saa Se S sag ona ean Sharia ie sen : Vist 

TRO (sn en eine eee ey H 

feet e eee eee eee e eee L 

wee ee ee ee ee ee eee H 

PBS rie | | ee ere teres L 

Vist= 1.8 X Vpp H=Vpp L=Vgs 


Figure 6-1: Mode Entry Diagram 


6.5 EPROM Programming 


The 11.5K bytes of USER EPROM is positioned at $1000 through $3DFF with the vector 
space from $3FFO to $3FFF. The erased state of EPROM is read as $FF and EPROM 
power is supplied from VPP and VDD pins. 


The Programming Control Register (PCR) is provided for the EPROM programming. The 
function of EPROM depends on the device operating mode. 


In the User Mode, ELAT and PGM bits in the PCR are available for the user read/write and 
the remaining test bits become read only bits. 


Please contact Motorola for Programming boards availability. 


6.5.1 Programming Sequence 
The EPROM programming is as follows: 


- Set the ELAT bit 

- Write the data to the address to be programmed 
- Set the PGM bit 

- Delay for the appropriate amount of time 

- Clear the PGM and the ELAT bit 


The last item may be done on a single CPU write. It is important to remember that an 
external programming voltage must be applied to the VPP pin while programming, but it 
should remain between VDD and VSS during normal operation. 
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6.5.2 Programming Control Register (PCR) 
Program control register is provided for EPROM programming the device. 


7 6 5 4 3 2 1 0 
PCR ie ELAT PGM 
$001D |w 
reset > 0 0 0 0 0 0 0 0 


ELAT—EPROM Latch Control 
0 - EPROM address and data bus configured for normal read. 
1- EPROM address and data bus configured for programming (writes to 
EPROM cause address and data to be latched). EPROM is in programming 
mode and can not be read. This bit is not writable to 1 when no VPP voltage 
is applied to the VPP pin. 


PGM—EPROM Program Command 
0 - Programming power to EPROM array is switched off. 
1 - Programming power to EPROM array is switched on. 


6.6 Low Power Modes 


The MC68HCO5BD7 has ONLY ONE low-power operational mode. The WAIT instruction 
provides the only mode that reduces the power required for the MCU by stopping CPU 
internal clock. The WAIT instruction is not normally used if the COP Watchdog Timer is 
enabled. The STOP instruction is not implemented in its normal sense. The STOP 
instruction will be interpreted as the NOP instruction by the CPU if it is ever encountered. 
The flow of the WAIT mode is shown in Figure 6-2. 


6.6.1 STOP Instruction 


Since the execution of a normal STOP instruction results in the stoppage of clocks to all 
modules, including the COP Watchdog Timer, this instruction is hence not implemented in 
its usual way to make COP Watchdog Timer meaningful in monitor applications. Execution 
of the STOP instruction will be the same as that of the NOP instruction. Hence, | bit in the 
Condition Code Register will not be cleared. 


6.6.2 WAIT Instruction 


In the WAIT Mode the internal processor clock is halted, suspending all processor and 
internal bus activity. Other Internal clocks remain active, permitting interrupts to be 
generated from the Multi-Function Timer, or a reset to be generated from the COP 
Watchdog Timer. The Timer may be used to generate a periodic exit from the WAIT Mode. 
Execution of the WAIT instruction automatically clears the I-bit in the Condition Code 
Register, so that any hardware interrupt can wake up the MCU. All other registers, memory, 
and input/output lines remain in their previous states. 


SECTION 6: OPERATING MODES 
Page 31 


For More Information On This Product, 
Go to: www.freescale.com 


GENEHAL RELEASE spreeseale Semiconductor, WG6sHUUSBU/ Hev. z.U 


6.7 COP Watchdog Timer Considerations 


The COP Watchdog Timer is always enable in MC68HCO5BD7. It will reset the MCU when 
it times out. For a system that must have intentional uses of the WAIT Mode, care must be 
taken to prevent such situations from happening during normal operations by arranging 
timely interrupts to reset the COP Watchdog timer. 


WAIT 


External Oscillator Active, 
and Internal 
Timer Clock Active 


J 


Stop Internal Processor Clock, 
Clear I-Bit in CCR 


External 
RESET? 


nternal 
COP 
RESET? 


Internal 
Interrupt? 


Vv 
Restart 
Internal Processor Clock 


Vv 
1.Fetch Reset Vector 
or 
2.Service Interrupt 
a.Stack 
b.Set I-Bit 
c.Vector to Interrupt Routine 


Figure 6-2: WAIT Flowcharts 
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SECTION 7 INPUT/OUTPUT PORTS 


In the User Mode there are 26 bidirectional I/O lines arranged as 4 I/O ports (Port A, B, C, 
and D). The individual bits in these ports are programmable as either inputs or outputs 
under software control by the data direction registers (DDRs). Also, if enabled by software, 
Port C and D will have additional functions as PWM outputs, DDC I/O and Sync Signal 
Processor outputs. 


7.1 Port A 


Port A is an 8-bit bidirectional port which does not share any of its pins with other 
subsystems. The Port A data register is at $00 and the data direction register (DDR) is at 
$04. Reset does not affect the data register, yet clears the data direction register, thereby 
returning the ports to inputs. Writing a one to a DDR bit sets the corresponding port bit to 
output mode. 


7.2 Port B 


Port B is a 6-bit bidirectional port which does not share any of its pins with other 
subsystems. PB2 to PB5 are +12V open-drain port pins. The Port B data register is at $01 
and the data direction register (DDR) is at $05. Reset does not affect the data register, yet 
clears the data direction register, thereby returning the ports to inputs. Writing a one toa 
DDR bit sets the corresponding port bit to output mode. 


7.3 Port C 


Port C is an 8-bit bidirectional port which shares pins with PWM, Sync Processor, and ADC 
subsystem. See SECTION 8 for a detailed description of PWM, SECTION 10 for a detailed 
description of SYNC Processor, and SECTION 12 for a detailed description of ADC. These 
pins are configured as PWM outputs when the corresponding bits in the CONFIGURATION 
REGISTER 1 are set. PC6 and PC7 are configured to VSYNO and HSYNO outputs when 
the corresponding bits in the CONFIGURATION REGISTER 2 are set. And PC2 to PC5 are 
configured as ADC input channels as the corresponding bit in the CONFIGURATION 
REGISTER 2 are set. If there is any confliction between the two configuration registers, the 
CONFIGURATION REGISTER 2 has higher priority. The Port C data register is at $02 and 
the data direction register (DDR) is at $06. Reset does not affect the data register, but 
clears the data direction register, thereby returning the ports to inputs. Writing a one to a 
DDR bit sets the corresponding port to output mode. 


7.4 Port D 


Port D is a 4-bit bidirectional port. PDO and PD1 shares their pins with DDC12AB 
subsystem. See SECTION 9 for a detailed description of DDC12AB. These two pins are 
configured to the corresponding functions when the corresponding bits in the 
CONFIGURATION REGISTER 2 are set. They have open-drain output and hysteresis 
input level to improve noise immunity. PD2 is a +5V open-drain general I/O pin which 
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shares its pin with the CLAMP output. See SECTION 10 for the description of CLAMP 
signal. It becomes the CLAMP output when the CLAMP bit in SPIOCR register is set. PD3 
is a +12V open-drain I/O pin which shares its pin with the SOG input. Also see SECTION 
10 for the description of SOG input. It is configured as SOG input when the SOG bit in 
SPIOCR register is set. The Port D data register is at $03 and the data direction register 
(DDR) is at $07. Reset does not affect the data register, yet clears the data direction 
register, thereby returning the ports to inputs. Writing a one to a DDR bit sets the 
corresponding port bit to output mode. 


7.5 Input/Output Programming 


Bidirectional port lines may be programmed as an input or an output under software control. 
The direction of the pins is determined by the state of the corresponding bit in the port data 
direction register (DDR). Each port has an associated DDR. Any I/O port pin is configured 
as an output if its corresponding DDR bit is set. A pin is configured as an input if its 
corresponding DDR bit is cleared. 


During Reset, all DDRs are cleared, which configure all port pins as inputs. The data 
direction registers are capable of being written to or read by the processor. During the 
programmed output state, a read of the data register actually reads the value of the output 
data latch and not the I/O pin. See Figure 7-1 and. 


Read/Write DDR 


>| Data Direction 
——>| Register Bit 


Write Data Data VO 
7) Register Bit I QTL PIN 
Read Data | <I 


Internal HCOS Reset__| 
Data Bus (RST) 
Figure 7-1: Port I/O Circuitry 
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Table 7-1: I/O Pin Functions 


RW DDR /0 Pin Functions 
0 0 The I/O pin is in input mode. Data is written into the output data latch. 
0 1 Data is written into the output data latch and output to the 1/0 pin. 


1 0 The state of the 1/0 pin is read. 


1 1 The I/O pin is in output mode. The output data latch is read. 


NOTE: A “glitch” can be generated on an I/O pin when changing it from an input 
to an output unless the data register is first pre-conditioned to the desired 
state before changing the corresponding DDR bit from a zero to a one. 


7.6 Port C and D Configuration Register 


Port C and Port D are shared with PWM, ADC, DDC12AB, and SYNC Processor. The 
configuration registers at $0A and $0B are used to configure those I/O pins. They are 
default to zero after poWer-on reset. Setting these bits will set the corresponding pins to 
the corresponding functions. For example, setting SCL and SDA bits of register $0B will 
configure Port D pins 1 and 0 as DDC12AB pins, regardless of DDR1 and DDRO settings. 


7 6 5 4 3 2 1 0 
R 
CR1 PWM15 PWM14 PWM13 PWM12 PWM11 PWM10 PWMg PWM8 
$000A |w 
reset > 0 0 0 0 0 0 0 0 
7 6 5 4 3 2 1 0 
R 
CR2 HSYNO VSYNO ADC3 ADC2 ADC1 ADCO SCL SDA 
$000B |w 
reset > 0 0 0 0 0 0 0 0 


When any PWM8-PWM15 bits of CR1 register are set, the corresponding pins of port C 
become the PWM output if the corresponding bits in CR2 register are clear. When the pin 
is defined as PWM channel, it become an output only pin. When any ADC3-ADCO bits of 
the CR2 register are set, the corresponding pins of port C become the ADC input channels. 
When HSYNO or VSYNO is set, the PC2 or PC3 becomes the output of HSYNC or VSYNC 
accordingly, see SECTION 10 for the detail description of HSYNO and VSYNO outputs. 
When SCL and SDA bits of the CR2 register are set, the DDC12AB use these two pins as 
clock and data pins. In summary, the configuration in the CR2 register has higher priority 
than in the CR1 register. 
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SECTION 8 PULSE WIDTH MODULATION 


There are 16 PWM channels. Channel 0 to channel 7 are dedicated PWM channels with 
5V open-drain option. Channel 8 to channel 15 are shared with ports C under the control 
of the corresponding configuration register. The channel 8 and channel 9 are 12V open- 
drain outputs. 


8.1 Operation of 8-Bit PWM 


Each 8-Bit PWM channel is composed of an 8-bit register which contains a 5-bit PWM in 
MSB portion and a 3-bit binary rate multiplier (BRM) in LSB portion. There are 16 data 
registers as shown in Figure 8-1 located from $20 to $2F. The value programmed in the 5- 
bit PWM portion will determine the pulse length of the output. The clock to the 5-bit PWM 
portion is the MCU clock and the repetition rate of the output is hence 62.5 KHz at 2 MHz 
MCU clock. 


The 3-bit BRM will generate a number of narrow pulses which are equally distributed 
among an 8-PWM-cycle frame. The number of pulses generated is equal to the number 
programmed in the 3-bit BRM portion. An example of the waveform is shown in Figure 8-2. 


Combining the 5-bit PWM together with the 3-bit BRM, the average duty cycle at the output 
will be (M+N/8)/32, where M is the content of the 5-bit PWM portion, and N is the content 
of the 3-bit BRM portion. Using this mechanism, a true 8-bit resolution PWM type DAC with 
reasonably high repetition rate can be obtained. 


7 6 5 4 3 2 1 0 
R 
PWMR OPWM4 OPWM3 OPWM2 OPWM1 OPWMO OBRM2 OBRM1 OBRMO 
$20-$2F | w 
reset > 0 0 0 0 0 0 0 0 


Figure 8-1: PWM Data Register 


The value of each PWM Data Register is continuously compared with the content of an 
internal counter to determine the state of each PWM channel output pin. Double buffering 
is not used in this PWM design. 
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M=s00 “ a > 
M = $01 : 
M= SOF | | ! 
7 Narrow pulse possibly inserted ee 7 


by the BRM 


T = 1 MCU Clock Period (0.5 us if MCU clock = 2 MHz) 


N PWM cycles in which narrow pulses are 
inserted in an 8-cycle frame 
XX1 4 
X1X 2,6 
1XX 1,3,5,7 


Figure 8-2: Relationship Between 5-Bit PWM and 3-Bit BRM 
8.2 Open-Drain Option Register 


This PWM Open-Drain option Register contains 8 bits which are programmed to change 
the output drive of individual PWM channel from channel 0 to channel 7 to be open-drain 
type. This register is located at $0012 


R 
PWMOR 7PWMO | 6PWMO | 5PWMO | 4PWMO | 3PWMO | 2PWMO | 1PWMO | OPWMO 
$12 |w 


reset > 0 0 0 0 0 0 0 0 


Figure 8-3: PWM Open-Drain Option Register 


When any bit in this register is one, the corresponding PWM channel output becomes +5V 
open-drain type. When the bit is zero, the corresponding PWM channel has push-pull 
output. All eight bits are clear upon reset. 
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SECTION 9 DDC12AB INTERFACE 


9.1 Introduction 


This DDC12AB Interface Module is mainly used for monitor to show its identification 
information to video controller. It contains DDC1 hardware and a two-wire, bidirectional 
serial bus which is fully compatible with multi-master IIC bus protocol to support DDC2AB 
interface. In DDC1 type of communication, the module is in transmit mode. For DDC2AB 
protocol, the module can be either in transmit mode or in receive mode upon host’s 
commands. When DDC1 hardware is enabled, the loaded data is serially clocked out to 
SDA line by the rising edge of VSYNC input signal continuously. If DDC2 protocol is 
selected, the module will act as a standard IIC module, and will response only when it is 
addressed or in master mode. During DDC1 communication, the falling transition in the 
SCL line can be detected to interrupt cpu for mode switching. 


This module not only can be applied in DDC12AB communication, but also can be used as 
one typical command reception serial bus for factory setup and alignment purpose. It also 
provides the flexibility of hooking additional devices to an existing system in future 
expansion without adding extra hardware. 


This DDC12AB module uses the SCL clock line and the SDA data line to communicate with 
external DDC host or IIC interface. These two pins are shared with PDO and PD1 port pins. 
The outputs of SDA and SCL pins are all open-drain type. It means no clamping diode 
connected between the pin and internal VDD. The maximum data rate typically is 100K bps. 
The maximum communication length and the number of devices that can be connected are 
limited by a maximum bus capacitance of 400 pF. 
9.2 DDC12AB Features 

* DDC1 hardware 

¢ Fully compatible with multi-master IIC Bus standard 

¢ Software controllable acknowledge bit generation 

¢ Interrupt driven byte by byte data transfer 

* Calling address identification interrupt 


¢ Auto detection of RW bit and switching of transmit or receive mode 
accordingly 


¢ Detection of START, repeated START, and STOP signals 

¢ Auto generation of START and STOP condition in master mode 

¢ Arbitration loss detection and No-ACK awareness in master mode 
¢ Master clock generator with 8 selectable baud rates 

¢ Automatic recognition of the received acknowledge bit 
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9.3 


Registers 


There are six different registers used in the DDC12AB module and the internal 
configuration of these registers is discussed in the following paragraphs. 


DDC Address Register (DADR) 


9.3.1 


DADR 
$0017 


7 6 5 4 3 2 1 0 
R 
DAD7 DAD6 DAD5 DAD4 DAD3 DAD2 DAD1 EXTAD 
WwW 
reset 1 0 1 0 0 0 0 0 


DAD7-DAD1 Bit 7-Bit 1 


EXTAD 


9.3.2 


DCR 
$0018 


reset > 


Bit 0 


These 7 bits can be the DDC2 interface’s own specific slave 
address in slave mode or the calling address when in master 
mode. So the program must update it as the calling address 
while entering the master mode and restore its own slave 
address after the master mode is quitted. This register is 
cleared as $A0 upon reset. 

The EXTAD bit is set to expand the calling address of this 
module. When it is one, the module will acknowledge the 
general call address $00 and the address comparison circuit 
will only compare the 4 MSB bits in the DADR register. For 
example, the DADR contains $A1, that means EXTAD is 
enabled and the calling address is $A0, therefore, the module 
can acknowledge the calling address of $00 and $A0 to $AF. 
When it is clear, the module will only acknowledge to the 
specific address which is stored in the DADR register. It is 
clear upon reset. 


DDC Control Register (DCR) 


7 6 5 4 3 2 1 0 
R 
DEN DIEN TXAK SCLIEN DDC1EN 
Ww 
0 0 X X 0 0 0 X 


The DCR provides five control bits. DCR is cleared upon reset. 


DEN 


DIEN 
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Bit 7 


Bit 6 


If the DDC module ENable bit (DEN) is set, the DDC module 
is enabled. If the DEN is clear, the interface is disabled and all 
flags will restore its power-on default states. Reset clears this 
bit. 

If the DDC Interrupt ENable bit (DIEN) is set, the interrupt 
occurs provided the TXIF or RXIF in the status register is set 
or the ALIF or NAKIF in the DMCR register is set and the I-bit 
in the Condition Code Register is cleared. If DIEN is cleared, 
the interrupt of TXIF, RXIF, ALIF, and NAKIF are all disabled. 
Reset clears this bit. 
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TXAK 


SCLIEN 


DDC1EN 


Bit 3 


Bit 2 


Bit 1 


If the transmit acknowledge enable bit (TXAK) is cleared, an 
acknowledge signal will be sent out to the bus at the 9th clock 
bit after receiving 8 data bits. When TXAK is set, no 
acknowledge signal will be generated at the 9th clock (i.e., 
acknowledge bit = 1). Reset clears this bit. 

If the SCL Interrupt ENable bit (SCLIEN) is set, the interrupt 
occurs provided the SCLIF in the status register is set and the 
l-bit in the Condition Code Register is cleared. If SCLIEN is 
cleared, the interrupt of SCLIF is disabled. Reset clears this 
bit. 

When DDC1 protocol ENable (DDC1EN) is set, the VSYNC 
input will be selected as clock input of DDC module. Its rising 
edge will continuously clock out the data in the shift register. 
No calling address comparison is performed. The RW bit in 
the status register will be fixed to be one. If this bit is clear, the 
SCLIF bit in the status register is also cleared. Reset clears 
this bit. 


9.3.3 DDC Master Control Register (DMCR) 


7 5 4 3 2 1 0 
R 
DMCR ALIF NAKIF BB MAST MRW BR2 BRI BRO 
$0016 |w 
reset > 0 0 0 0 0 0 0 


The DMCR contains two interrupt flags, one bus status flag, two master mode control bits, 
and three baudrate select bits. 


ALIF 


NAKIF 


BB 


Bit 7 


Bit 6 


Bit 5 


The Arbitration Loss Interrupt Flag is set when software 
attempt to set MAST but the BB has been set by detecting the 
start condition on the lines or when the DDC12AB module is 
transmitting a’one’ to SDA line but detected a ’zero’ from SDA 
line in master mode, which is so called arbitration loss. This 
bit can generate an interrupt request to cou when the DIEN bit 
in DCR register is set and I-bit in the Condition Code Register 
is clear. This bit is cleared by writing ’0’ to it or by reset. 

The No AcKnowledge Interrupt Flag is only set in master 
mode when there is no acknowledge bit detected after one 
data byte or calling address is transferred. This bit can 
generate an interrupt request to cou when the DIEN bit in 
DCR register is set and I-bit in the Condition Code Register is 
clear. This bit is cleared by writing ’0’ to it or by reset. 

The Bus Busy Flag is set after a start condition is detected, 
and is reset when a stop condition is detected. This bit can 
supplement the software in initiating the master mode 
protocol. Reset clears this bit. 
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MAST 


MRW 


BR2-BRO 
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Bit 4 


Bit 3 


Bit 2-Bit 0 


If the software set the MASTer control bit, the module will 
generate a start condition to the SDA and SCL lines and send 
out the calling address which is stored in the DADR register. 
But if the ALIF flag is set when arbitration loss occurs on the 
lines, the module will discard the master mode by clearing the 
MAST bit and release both SDA and SCL lines immediately. 
This bit can also be cleared by writing zero to it or when the 
NAKIF is set. When the MAST bit is cleared either by NAKIF 
set or by software, not by ALIF set, the module will generate 
the stop condition to the lines after the current byte 
transmission is done. Reset clears this bit. 

This MRW bit will be transmitted out as the bit 0 of the calling 
address when the module sets the MAST bit to enter the 
master mode. It will also determine the transfer direction of 
the following data bytes. When it is one, the module is in 
master receive mode. When it is zero, the module is in master 
transmit mode. Reset clears this bit. 

The three Baud Rate select bits will select one of eight clock 
rates as the master clock when the module is in master mode. 
The serial clock frequency is equal to the CPU clock divided 
by the divider shown in following table. For the CPU clock will 
be halted while program executes the WAIT instruction, 
program must not enter WAIT mode when the DDC12AB 
module is in Master mode in order not to hang up the 
communication on the lines. These bits are cleared upon 
reset. 


BR2:BR1:BRO DIVIDER 
0:0:0 20 
0:0:1 40 
0:1:0 80 
0:1:1 160 
1:0:0 320 
1:0:1 640 
1:1:0 1280 
1:1:1 2560 


Table 9-1: Pre-scaler of Master Clock Baudrate 
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9.3.4 


DSR 
$0019 


DDC Status Register (DSR) 


This status register is readable only. All bits are cleared upon reset except bit 3 (RXAK) and 
bit 1 (TXBE). 


7 


5 4 3 2 1 0 


R | RXIF 


TXIF 


MATCH SRW | RXAK SCLIF TXBE RXBF 


WwW 


reset > 0 


RXIF 


TXIF 


MATCH 


SRW 


RXAK 


SCLIF 


Bit 7 


Bit 6 


Bit 5 


Bit 4 


Bit 3 


Bit 2 


The data Receive Interrupt Flag (RXIF) is set after the DDRR 
is loaded with a newly received data. Once the DDRR is 
loaded with received data, no more received data can be 
loaded to the DDRR register. The only way to release the 
DDRR register for loading next received data is that software 
reads the data from the DDRR register to clear RXBF flag. 
This bit is cleared by writing ’0’ to it or when the DEN is 
disabled. 

The data Transmit Interrupt Flag is set before the data of the 
DDTR register is downloaded to the shift register. It is 
software’s responsibility to fill the DDTR register with new 
data when this bit is set. This bit is cleared by writing ’0’ to it 
or when the DEN is disabled. 

The MATCH flag is set when the received data in the DDRR 
register is an calling address which matches with the address 
or its extended addresses (EXTAD=1) specified in the DADR 
register. 

The Slave RW bit will indicate the data direction of DDC 
protocol. It is updated after the calling address is received in 
the DDC2 protocol. When it is one, the master will read the 
data from DDC module, so the module is in transmit mode. 
When it is zero, the master will send data to the DDC module, 
the module is in receive mode. When DDCiEN is set, the 
SRW bit will be one. The reset state of it is zero. 

If the received acknowledge bit (RXAk) is low, it indicates an 
acknowledge signal has been received after the completion of 
8 data bits transmission on the bus. If RXAK is high, it 
indicates no acknowledge signal has been detected at the 9th 
clock. Then the module will release the SDA line for the 
master to generate stop’ or repeated start’ condition. It is set 
upon reset. 

This SCLIF flag is set by the falling edge of SCL line only 
when DDC1EN is enabled. This bit is cleared by writing zero 
to it, clearing DDC1EN bit or when the DEN is disable. 
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TXBE Bit 1 The Transmit Buffer Empty (TXBE) flag indicates the status of 
the DDTR register. When the cpu writes the data into the 
DDTR register, the TXBE flag will be cleared. And it will be set 
again after the data of the DDTR register has been loaded to 
the shift register. It is default to be set when the DEN is 
disable and will be cleared by writing data to the DDTR 
register when the DEN is enabled. 

RXBF Bit 0 The Receive Buffer Full (RXBF) flag indicates the status of the 
DDRR register. When the cpu reads the data from the DDRR 
register, the RXBF flag will be cleared. And it will be set after 
the data or matched address is transferred from the shift 
register to the DDRR register. It is cleared when DEN is 
disabled or DDRR register is read when DEN is enabled. 


9.3.5 DDC Data Transmit Register (DDTR) 
7 6 5 4 3 2 1 0 


R 
DDTR DTD7 DTD6 DTD5 DTD4 DTD3 DTD2 DTD1 DTDO 
$001A |w 


reset > 1 1 1 1 1 1 1 1 


The data written into this register after DEN is enabled will be automatically downloaded to 
the shift register when the module detects the calling address is matched and the bit 0 of 
the received data is one or when the data in the shift register has been transmitted with 
received acknowledge bit, RXAK=0. So if the program doesn't write the data into the DDTR 
register (TXBE is cleared) before the matched calling address is detected, the module will 
pull down the SCL line. If the cpu write a data to the DDTR register, then the written data 
will be downloaded to the shift register immediately and the module will release the SCL 
line, then the TXBE is set again and the TXIF flag is set to generate another interrupt 
request for data. So the cpu may need to write the next data to the DDTR register to clear 
TXBE flag and for the auto downloading of data to the shift register after the data in the shift 
register is transmitted over again with RXAK=0. If the master receiver doesn’t acknowledge 
the transmitted data, RXKAK=1, the module will release the SDA line for master to generate 
‘stop’ or ’repeated start’ conditions. The data stored in the DDTR register will not be 
downloaded to the shift register until next calling from master (TXBE remains unchanged). 


9.3.6 DDC Data Receive Register (DDRR) 


7 6 5 4 3 2 1 0 
R DRD7 DRD6 DRD5 DRD4 DRD3 DRD2 DRD1 DRDO 
DDRR 
$001B |w 
reset > 0 0 0 0 0 0 0 0 


The DDC Data Receive Register (DDRR) contains the last received data when the MATCH 
flag is zero or the calling address from master when the MATCH flag is one. The DDRR 
register will be updated after a data byte is received and the RXBF is zero. It is a read-only 
register. The read operation of this register will clear the RXBF flag. After the RXBF flag is 
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cleared, the register can load the received data again and set the RXIF flag to generate 
interrupt request for reading the newly received data. 


9.4 Data Sequence 


a) Master Transmit mode 


[START] [Adcress [ol Aon|[TX Datei] * [TX Data [| STOP] 
N N 


TXBE=0 TXIF=1 TXIF=1 NAKIF=1 
MAST=1 TXBE=1 TXBE=1 MAST=0 
MRW=0 TXBE=0 


b) Master Receive mode 


[START] Adcress [i] Aon[AX Datalpo, ”“ " [AX Daten [| STOP] 
\ A A 


I I I 
RXBF=0 RXIF=1 RXIF=1 


MAST=1 RXBF=1 RXBF=1 
NAKIF=1 
c) Slave Transmit mode MAST=0 


[START [Adaress [OT Datei] Od,” * [TX Data fd [STOP] 
N A A 


TXBE=0 RXIF=1 TXIF=1 
RXBF=0 RXBF=1 TXBE=1 
TXiF=1 
TXBE=1 
MATCH=1 


; RW=1 
d) Slave Receive mode - 


[START [Adaress [o][AO4[AX Datai[pog” [AX Daan] fad [STOP] 
\ A A \ 


TXBE=0 RXIF=1 RXIF=1 RXIF=1 
RXBF=0 RXBF=1 RXBF=1 RXBF=1 
MATCH=1 
SRW=0 


9.5 Program Algorithm 


The Figure 9-1 shows the algorithm of slave mode interrupt routine of DDC12B protocol. 
The Figure 9-2 shows the algorithm of master mode setup and interrupt service routine. 


When the DDC module detects an arbitration loss in master mode, it will release both SDA 
and SCL lines immediately. But if there is no further "stop condition" detected, the module 
will be hanged up. So it is recommended to have time-out software to recover from such ill 
condition. The software can start the time-out counter by looking at the BB (Bus Busy) in 
the bit 5 of DMCR and reset the counter when the completion of one byte transmission. If 
the time-out occurred, program can clear DEN bit to release the bus, and then set DEN bit 
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and DDC1EN bit to clear BB flag (This is the only way to clear BB flag by software while 
the module is hanged up due to no "stop condition" received). The program can resume IIC 
master mode after clearing the BB flag and DDC1EN bit. 
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Interrupt 


Y 


Clear TXIF 
Write Data 
to DDTR 


Clear RXIF 
Read Data 
from DDRR 


Clr DDC1EN 
Clr SCLIEN MATCH. Y 
Clr SCLIF =? Y 
< Address 


received 


Write 
TXAK for 
Next Byte 

Receive 


Figure 9-1: Software Flowchart of Slave Mode Interrupt Routine 
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Interrupt 


Y 
Y 
Lb < BB i? 
—EE lear ALIF Set 
N "Failure" flag 
¥. for retry 
Pups { Y restore DADR 
DIEN <= 1 Clr NAKIF 


<< | Clr TXIF 


Clear RXIF 
Read DDRR 


Next Data 


"Incomplete" a 


flag for retry 


*restore DADR 
WAIT 


y 
DDTR <= $FF 


*restore DADR MAST <=0 
‘restore DADR 


RTI 
*“ TXAD means transmit address * Restore its own specific slave address 
*** TXAK is 1 when master (6) Master mode interrupt routine 


want receive only one byte 
(a) Master mode setup 


Figure 9-2: Software Flowchart in Master mode: (a) Mode setup. (b) Interrupt routine 
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SECTION 10 SYNC PROCESSOR 


10.1 Introduction 


The functions of the module include polarity detection, horizontal frequency counter, 
vertical frequency counter, and polarity controllable HSYNO and VSYNO outputs of various 
input sources, such as separate H & V, Composite Sync from HSYNC, Sync-On-Green, or 
internal free running H & V pulses. Besides, it also provides the CLAMP pulse output to the 
external Pre-Amp chip. The SOGIN bit in SPIOCR register will determine the Composite 
Sync input pin. All HSYNC, VSYNC, and SOG inputs have internal schmitt trigger to 
improve noise immunity. 


10.2 Functional Blocks 


10.2.1 Polarity Detection 


The HSYNC polarity detection circuit will measure the length of high period of HSYNC 
inputs. If the length of high is longer than 7us and the length of low is shorter than 6us, the 
HPOL bit will be zero, indicates negative polarity. If the length of low is longer than 7us and 
the length of high is shorter than 6us, the HPOL bit is one, positive polarity. The VSYNC 
polarity detection circuit perform the similar structure with HSYNC polarity detection circuit. 
If the length of high is longer than 4ms and the length of low is shorter than 2ms, the VPOL 
bit will be zero, indicates negative polarity. If the length of low is longer than 4ms and the 
length of high is shorter than 2ms, the VPOL bit is one, positive polarity. Both HSYNC and 
VSYNC polarity flags are read-only, and will not affect any internal circuitry. When the 
COMP bit in SPCSR register is set, the HPOL bit will be the same as VPOL bit which is 
detected under the criteria stated in previous statements. 


10.2.2 Sync Signal Counters 


There are two counters (horizontal frequency counter and vertical frequency counter) to 
count the number of horizontal sync pulses within 32ms period and the number of system 
clock cycles between two vertical sync pulses. These two data can be read by the CPU to 
check the signal frequencies and can be used to determine the video mode. The 13-bit 
vertical frequency register encompasses vertical frequency range from about 15 Hz to 127 
Hz. Due to the asynchronous timing between incoming VSYNC and internal processor 
clock, there will be +1 count error on the reading from the register for the same vertical 
frequency. The horizontal counter counts the pulses on HSYNC pin, and is uploaded to the 
$0F and $10 registers every 32.768ms. The step unit in the lower 5-bit register is 
0.3125KHz. And the least 7 bits in the HFHR register shows the number of KHz of incoming 
HSYNC signal. The MSB of the HFHR is the overflow flag of H-counter, which will be 
cleared when the register is read by CPU. 


10.2.3. Polarity Controlled HSYNO/VSYNO Outputs 


The input HSYNC and VSYNC signal can be output to PC6 and PC7 when the 
configuration bit of PC6 and PC7 in register $0B are set for SYNC output. Two 
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corresponding polarity control bits, bit 3 and bit 2 of register $0C, can change the polarity 
of HSYNO/VSYNO outputs. The result HSYNO and VSYNO outputs can vary while the 
setting in SPCSR and SPIOCR register is different. If the COMP bit in SPCSR register is 
set, the incoming composite Sync signal will be the HSYNO output and the extracted 
VSYNC with 6~7us delay will be the VSYNC output. When the SOUT bit in SPIOCR 
register is set, the internal free-running 55.556KHz with 2us pulse will be the HSYNO 
output and the other free-running 72.34Hz with 108us pulse will be the VSYNO output. 


10.2.4 CLAMP Pulse Output 


The logic will generate a 0.5us - 0.75us pulse at either the leading edge or the trailing edge 
which is specified by the BPOR bit in the SPIOCR register. See Figure 10-1 for its detail 
timing relation. One control bit to invert the output polarity of CLAMP pulse is located at bit 
5 of SPIOCR. 


HSYNC 
(HPOL=1) 
CLAMP 
(BPOR=0) 
CLAMP 
(BPOR=1) 

ee > ~<t 

0.5-0.75us 0.5-0.75us 
HSYNC 
(HPOL=0) 
CLAMP 
(BPOR=0) 

> 
0.5-0.75's 

CLAMP 
(BPOR=1) 

> ~< 

0.5-0.75us 

Figure 10-1: CLAMP output waveform 
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10.3. Registers 


There are five registers associated with the SYNC PROCESSOR module as described 


below. 


10.3.1 Sync Processor Control and Status Register (SPCSR) 


NOTE: Please don’t use BSET or BCLR to manipulate this register when VSIE is 
set and I-bit is clear, or it will cuase abnormal reset. 


5 4 3 2 1 0 


R 


SPCSR 


$000C |w 


VSIF VPOL HPOL 
VEDGE COMP VINVO HINVO 


reset > 


VSIE 


VEDGE 


VSIF 


COMP 


VINVO 


bit 6 


bit 5 


bit 4 


bit 3 


When VSync Interrupt Enable (VSIE) bit is set, the VSIF flag 
is enabled to generate an interrupt request to the CPU. When 
VSIE is cleared, the VSIF flag is prevented from generating an 
interrupt request. Reset clears this bit. 

The VEDGE bit specifies the triggering edge of VSYNC 
interrupt. When it is zero, the rising edge of internal VSYNC 
signal which is either from the VSYNC pin or extracted from 
the composite input signal will set VSIF flag. When it is one, 
the falling edge of internal VSYNC signal will set VSIF flag. 
Reset clears this bit. 

This flag is a read-only bit and is set by the specified edge of 
internal VSYNC signal which is either from the VSYNC pin or 
extracted from the composite input signal. The triggering 
edge is specified by the VEDGE bit, see the above description 
of VEDGE for details. It is cleared by writing a zero to it or 
reset. 

This COMPosite video input enable bit is set to enable the 
separator circuit which extracts the VSYNC pulse from 
composite input in HSYNC pin. The extracted VSYNC pulse 
will be fed into the vertical counter, vertical polarity detection 
circuit, and VSYNO output circuit as well. Its measurable 
timing is the same as the separate VSYNC pin input. Reset 
clears this bit. 

This bit controls the output polarity of the VSYNO signal. 
When it is zero, the VSYNO output is identical to the VSYNC 
input. When it is one, the inverted VSYNC signal is output to 
VSYNO pin. 
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HINVO 


VPOL 


HPOL 


bit 2 


bit 1 


bit 0 


This bit controls the output polarity of the HSYNO signal. 
When it is zero, the HSYNO output is identical to the HSYNC 
input. When it is one, the inverted HSYNC signal is output to 
HSYNO pin. 

This bit shows the polarity of VSYNC input. If it is one, the 
VSYNC input has positive polarity. If it is zero, the VSYNC 
input has negative polarity. Reset clears this bit. 

This bit shows the polarity of HSYNC input. If it is one, the 
HSYNC input has positive polarity. If it is zero, the HSYNC 
input has negative polarity. Reset clears this bit. 


10.3.2 Sync Processor Input/Output Control Register (SPIOCR) 


7 


R VSYNCS H 
SPIOCR 
$0011 w 


reset > 


VSYNCS 
HSYNCS 


COINV 


HVTST 


SOGIN 


CLAMPOE 


BPOR 


SOUT 
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0 


bit 7 


bit 6 


bit 5 


bit 4 


bit 3 


bit 2 


bit 1 


bit 0 


6 5 4 3 2 1 0 
SYNCS 
COINV HVTST SOGIN CLAMPOE BPOR SOUT 
0 0 0 0 0 0 0 


The VSYNCS bit reflects the logical state of VSYNC input. It 
is a read only bit. 

The HSYNCS bit reflects the logical state of HSYNC input. It 
is a read only bit. 

This Clamp Output INVert bit will invert the CLAMP output. 
When it is zero, the CLAMP output has default positive going 
pulse as illustrated in Figure 10-1. When it is one, the CLAMP 
output is inverted as negative pulse generated. Reset clears 
this bit. 

This HV TeST bit is reserved for testing purpose. It can be 
accessed only in test mode. So user must be careful while 
developing the program in EVS platform. Reset clears this bit. 
If the SOGIN bit is one, the SOG pin which is shared with PD3 
will be selected as the composite sync input when the COMP 
bit in SPCSR register is one. If it is zero, the HSYNC pin is the 
default composite input pin when the COMP bit is one. Reset 
clears this bit. 

The CLAMP Output Enable bit is set to configure the PD2 pin 
as the CLAMP pulse output pin. Reset clear this bit. 

The Back PORch bit defines the triggering edge of clamp 
output. When it is one, the clamp pulse is generated at the 
trailing edge of HSYNC input. When it is zero, the clamp pulse 
is generated at the leading edge of HSYNC input. Reset 
clears this bit. 

The SOUT will select the output signals of VSYNO and 
HSYNO from the internal free-running counter. When it is 
zero, the incoming HSYNC and VSYNC or extracted VSYNC 
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will be output to the HSYNO and VSYNO pins. When it is one, 
the free-running 55.556KHz HSYNC with 2us negative pulse 
and 72.34Hz VSYNC with 108us negative pulse will be 
generated to the HSYNO and VSYNO output stages. Reset 
clears this bit. 


10.3.3 Vertical Frequency Registers (VFRs) 
7 6 5 4 3 2 1 0 
R VOF 0 0 VF12 VF 11 VF10 VF9 VF8 
VFHR 
$000D |w 
reset > 0 0 0 0 0 0 0 0 
7 6 5 4 3 2 1 0 
R VF7 VF6 VF5 VF4 VF3 VF2 VF1 VFO 
VFLR 
$000E |w 
reset > 0 0 0 0 0 0 0 0 
VFR Max Freq Min Freq VFR Max Freq Min Freq 
$03C0 130.34 Hz 130.07 Hz $0823 60.04 Hz 59.98 Hz 
$03C1 130.21 Hz 129.94 Hz $0824 60.01 Hz 59.95 Hz 
$03C2 130.07 Hz 129.80 Hz $0825 59.98 Hz 59.92 Hz 
$04E2 100.08 Hz 99.92 Hz $09C4 50.02 Hz 49.98 Hz 
$04E3 100.00 Hz 99.84 Hz $09C5 50.00 Hz 49.96 Hz 
$04E4 99.92 Hz 99.76 Hz $09C6 49.98 Hz 49.94 Hz 
$06F9 70.07 Hz 69.99 Hz $1FFD 15.266 Hz 15.262 Hz 
$O6FA 70.03 Hz 69.95 Hz $1FFE 15.264 Hz 15.260 Hz 
$06FB 69.99 Hz 69.91 Hz $1FFF 15.262 Hz 15.258 Hz 


This 13-bit read only register pair contains information of the vertical frame frequency. An 
internal counter counts the number of internal clocks between two VSYNC pulses. The 
most significant 5 bits of counted value will then be transferred to high byte register, $0D, 
and the least significant 8 bits of counted value is transferred to one intermediate buffer. 
When the high byte register is read, the 8-bit counted value stored in the intermediate buffer 
will be uploaded to the low byte register, $0E. So the program must read the high byte 
register first then low byte register in order to get the complete counted value of one vertical 
frame. If the counter overflow, the VOF flag will be set while the counter values stored in 
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the VFRs registers are meaningless. The data corresponds to the period of one vertical 
frame. This register can be read to determine if the frame frequency is valid, and to 
determine the video mode. The MSB in the VFHR register will indicate the overflow 
condition when the period of VSYNC frame exceeds 64.768ms (lower than 15.258Hz). This 
VOF flag is default to be zero and will be update every vertical frame or set when the 
counter overflows. 


The frame frequency is calculated by 1/(VFR+1 x 8uS) or 1/(VFR+1 x 16 x tcyc). 


The table above shows examples for the Vertical Frequency Register, all VFR numbers are 
in hexadecimal: 


10.3.4 | Hsync Frequency Registers (HFRs) 


7 6 5 4 3 2 1 0 
R HOVER HFH6 HFH5 HFH4 HFH3 HFH2 HFH1 HFHO 
HFHR 
$O000F |w 
reset > 0 0 0 0 0 0 0 0 
7 6 5 4 3 2 1 0 
R 0 0 0 HFL4 HFL3 HFL2 HFL1 HFLO 
HFLR 
$0010 |w 
reset > 0 0 0 0 0 0 0 0 


This 13-bit read-only register pair contains the number of horizontal lines within 32ms and 
one overflow bit, HOVER. An internal line counter counts the horizontal sync pulses within 
32ms window of every 32.768ms period. The most significant 7 bits of counted value will 
then be transferred to high byte register, $0F, and the least significant 5 bits of counted 
value is transferred to one intermediate buffer. When the high byte register is read, the 5- 
bit counted value stored in the intermediate buffer will be uploaded to the low byte register, 
$10. So the program must read the high byte register first then low byte register in order to 
get the complete counted value of horizontal pulses. The HOVER bit will be set immediately 
if the number of incoming horizontal sync pulses in 32ms are more than 4095, that means 
HSYNC frequency is over 128KHz. The HFHR data can be read to determine the number 
of KHz of HSYNC frequency and the HFLR shows the sub-KHz value of HSYNC frequency. 
This makes user easy to read the frequency of HSYNC and determine the video mode. 


10.4 System Operation 


This module is used mainly for user to determine the video mode of incoming HSYNC and 
VSYNC of various frequency and polarity. It is designed to assist in determining the video 
mode including DPMS modes. The definition of ’No pulses’ of DPMS standard can be 
detected when the value of H counter register is less than one or the VOF in the VFHR 
register is set. For the HSYNC counter value will be updated repeatedly every 32.768ms 
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and also we know the valid VSYNC pulse, more than 40Hz, could arrive in shorter time. So 
it is recommended that user reads the counter value every 32.768ms period. 
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SECTION 11 MULTI-FUNCTION TIMER 


11.1 Introduction 


This module provides miscellaneous function to the MC68HCO5BD7. It includes a timer 
overflow, real-time interrupt, and watchdog functions. Also included in the module is the 
capability of selecting the mode of the maskable external interrupt pin, either edge- 
triggered mode only or both edge-triggered mode and level-triggered mode. 


The clock base for this module is derived from bus clock divided by four. For a 2 MHz E 
(CPU) clock, the clock base is 0.5 MHz. This clock base is then divided by an 8-stage ripple 
counter to generate the timer overflow. Timer overflow rate is thus E/1024. The output of 
this 8-stage ripple counter then drives one stage divider to generate real time interrupt. 
Hence, the clock base for real time interrupt is E/2,048. Real time interrupt rate is selected 
by RTO and RT1 bits of Multi-Function Timer Control/Status Register (MFTCSR). The 
interrupt rates are E/2,048, E/(2,048X2), E/(2,048X4), and E/(2,048X8). The selected real 
time interrupt rate is then divided by 64 to generate COP reset. 


The COP watchdog timer function is implemented by using a COP counter. The minimum 
COP reset rates are controlled by RTO and RT1 of MFTCSR. If the COP circuit times out, 
an internal reset is generated and the normal reset vector is fetched. Preventing a COP 
time-out is done by writing a ‘0’ to bit 0 of address $3FFO. This write operation resets the 
divide-by-64 counter stage described in the previous paragraph. The COP counter has to 
be cleared periodically by software with a period less than COP reset rate. It continues to 
count even though the CPU is in WAIT mode. In MC68HCO5BD7, the COP is always 
enabled. 


11.2 Register 
There are two registers in the Multi-Function Timer as discussed below. 


11.2.1 Multi-function Timer Control/status Register 


NOTE: Please don’t use BSET or BCLR to manipulate this register when I-bit is 
clear, or it will generate abnormal reset. 


7 6 5 4 3 2 1 0 
R 
MFTCSR TOF RTIF TOFIE RTIE IRQN INHIRQ RT1 RTO 
$0008 |w 
reset > 0 0 0 0 0 0 1 1 
TOF bit 7 Timer Overflow Flag indicates if the 8-bit ripple counter 


overflows. TOF is set when the 8-bit counter rolls over from 
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RTIF 


TOFIE 


RTIE 


IRQN 


INHIRQ 


RT1-0 
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bit 6 


bit 5 


bit 4 


bit 3 


bit 2 


bit 1,0 


$FF to $00. A CPU interrupt request will be generated if 
TOFIE is set. TOF is a clearable, read-only status bit. Clearing 
the TOF is done by writing a ’0’ to TOF. 

Real Time Interrupt Flag indicates if the output of the RTI 
circuit goes active. The clock frequency that drives the RTI 
circuit is E/2,048, giving a maximum interrupt period of 1.024 
milliseconds at a bus rate of 2 MHz. A CPU interrupt request 
will be generated if RTIE is set. RTIF is a clearable, read-only 
status bit. Clearing the RTIF is done by writing a ’0’ to RTIF. 
When Timer Over Flow Interrupt Enable (TOFIE) bit is set, the 
TOF flag is enabled to generate an interrupt request to the 
CPU. When TOFIE is cleared, the TOF flag is prevented from 
generating an interrupt request. 

When Real Time Interrupt Enable (RTIE) is set, the RTIF flag 
is enabled to generate an interrupt request to the CPU. When 
RTIE is cleared, the RTIF flag is prevented from generating an 
interrupt request. 

0 = Both level and edge triggering are detected for external 
interrupt (IRQ). 

1 = Only edge triggering is detected for external interrupt. 
The INHibit IRQ bit will inhibit the external interrupt input. 
When it is set, no active falling edge or low period will be 
recognized as interrupt request. It is possible for a low state 
input on the IRQ pin to be seen as a falling edge event when 
the INHIRQ bit changes from one to zero, see Figure 4-2 for 
reference. Reset clears this bit. 

These two bits are used to define real time interrupt rate as 
well as COP reset rate as tabulated in Table 11-1. Reset sets 
these two bits for the slowest watchdog reset rate. Note that 
the minimal COP reset period is determined by dividing the 
COP master clock, which is the real time interrupt clock, by 
63(63=64-1). The reason is that COP reset operation is 
asynchronous to COP master clock edge. Therefore it is 
possible that right after COP reset operation, a COP master 
clock edge arrives to start counting COP period. The effective 
count of the divide-by-64 counter is hence 63 rather than 64. 
RT1, RTO should only be changed right after COP timer has 
been reset; otherwise, unpredictable result will occur. 
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RT1| RTO | Min. COP Reset Period @ 2 MHz E Clock RTI Period @ 2 MHz 
0 0 64.512 ms 1.024 ms 
0 1 129.024 ms 2.048 ms 
1 0 258.048 ms 4.096 ms 
{ { 516.096 ms 8.192 ms 


Table 11-1: COP Reset Rates and RTI Rates 
11.2.2 MFT Timer Counter Register 


7 6 5 4 3 2 1 0 
R| MFTCR7 MFTCR6 MFTCR5 MFTCR4 | MFTCR3 | MFTCR2 MFTCR1 MFTCRO 
MFTCR 
$0009 | w | | 
reset > 0 0 0 0 0 0 0 0 


This 8-bit free-running counter register, MFTCR, can be read at location $0009. It is cleared 
by reset. 
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SECTION 12 A/D CONVERTER 


12.1 Introduction 


The Analog-to-Digital Converter (ADC) system consists of four analog input channels and 
a single 6-bit D/A Converter and Comparator, with continuous conversion. A result flag 
indicates if the comparator output is above or below the analog Input. ADC is disabled by 
setting AD5 to ADO bits of ADC Control/Status Register to all 1’s. This disable function is 
mainly for low power application. 


ADCO or ADC1 or ADC2 or ADC3 


i =  SADS 
RESULT 2R 


——1+——c) AD4 


-—cC) AD3 


c> AD2 


R| OR 
Jo FES soa 


R| OR 


i——__) ADO 


~—Vdd 


Figure 12-1: Structure of A/D Converter 
12.2 Input 


The ADC has four multiplexed input channels. Only one of the four channels will be 
selected by CHSL1 and CHSLO bits as analog input. 


12.2.1. ADCO-ADC3 


The ADCO to ADC3 inputs are multiplexed with the PC2 to PC5 port pins. They are selected 
as ADC input then the corresponding ADO-AD3 bit in the CR2 register is one. The user can 
use the CHSL1 and CHSLO bits to select one of the four channels to do the A/D Conversion 
and get the approximate digital value of each input channel. 
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12.3 Registers 
12.3.1 ADC Control/status Register 


This read/write register, located at address $14, contains six control bits and one status bit. 


7 6 5 4 3 2 1 0 
R| RESULT 
ADCSR ADS5 AD4 AD3 AD2 AD1 ADO 
$0014 |w 
reset > 0 0 0 0 0 0 0 0 


RESULT - Comparator Status Bit (Read Only) 


When set, D/A output > ANALOG IN. 
When clear, D/A output > ANALOG IN. 


AD5:0 - A/D Digital Result 


These bits are written by the user to perform successive 
approximations in software. When a value causes the 
RESULT bit to change state from the value immediately 
before or after it, AD5:0 are considered to be the digital 
equivalent of the analog input. Note that when AD5:0 are all 
1’s, ADC is virtually turned off to minimize power 
consumption. 


12.3.2 | ADC Channel Register 
The ADC Channel Register, located at address $15 contains only two bits. 


7 6 5 4 3 2 1 0 
ADCCR ie CHSL1 CHSLO 
$0015 |w 
reset > 0 0 0 0 0 0 0 0 


CHSL1:CHSLO - Channel select bits 


These two bit will select one of the four ADC input channels 
as analog input source. Following table shows _ its 
configuration. 


CHSL1:CHSLO = 0 : 0 ==> ADCO 
CHSL1:CHSLO = 0: 1 ==> ADC1 
CHSL1:CHSLO = 1 : 0 ==> ADC2 
CHSL1:CHSLO = 1: 1 ==> ADC3 
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12.4 


The following example shows how to convert analog input channel 0 by using binary search 
method. This approach method will guarantee any conversion can be done within 6 
iterations, 98us at 2MHz bus clock. For ADCIN1 conversion, change #$00 to #$01. ADCCR 
is the ADC Channel Register. 


Program Example 


CR2 EQU SOB ; Configuration Register 
ADCCR EQU $15 ; ADC Channel Register 
ADCSR EQU $14 ; ADC Control & Status Register 
ADCDATAEQU $50 RAM byte to store the conversion result 
REFH FOU $51 RAM byte to store the high end of conversion 
REFL FOU $52 RAM byte to store the low end of conversion 
ORG $1000 
LDA #$3C 
STA CR2 ; Configure PC2-PC5 as ADC inputs 
LDA #500 
STA ADCCR ; Select the input channel 
LDA #500 
STA REFL ; initial low end = #$00 
LDA #S$3F 
STA REFH ; initial high end =#S3F 
DALP LDA REFH 
ADD REFL 
LSRA ; A= (REFH + REFL) /2 
STA ADCSR ; Store the comparison data to D/A 
CMP REFL ; Compare the stored value with REFL 
BEQ DONE ; If equal, the A is the result digital value 
BRSET 7,ADCSR,SETHI ; Check the RESULT flag 
STA REFL ; If lower, set A as the low end of conversion 
BRA DALP 
SETHI STA REFH ; If higher, set A as the high end of conversion 
BRA DALP 
DONE STA ADCDATA 


* Input voltage calculation at Vpp=5V: 


ADCDATA x 0.078125V < INPUT < (ADCDATA+1) x 0.078125V 
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SECTION 13 ELECTRICAL SPECIFICATIONS 


13.1 Maximum Ratings 


(Voltages referenced to Vss) 


Rating Symbol Value Unit 
Supply Voltage Vpp —0.3 to +7.0 V 
Input Voltage VIN Vgg —0.3 to Vpp +0.3 V 


IRQ Pin Vgg —0.3 to 2Vpp +0.3 V 
Current Drain Per Pin Excluding VDD and VSS 25 mA 


Operating Temperature Range 
MC68HCOS5BD7 (Standard) 0 to +70 °C 


Storage Temperature Range TstG —65 to +150 ne) 


This device contains circuitry to protect the inputs against damage due to high static 
voltages or electric fields; however, it is advised that normal precautions be taken to avoid 
application of any voltage higher than maximum-rated voltages to this high-impedance 
circuit. For proper operation, it is recommended that Vj, and Voyz be constrained to the 
range Vsg < (Vin Or Vout) < Vpp- Reliability of operation is enhanced if unused inputs are 
connected to an appropriate logic voltage level (e.g., either Vss or Vpp). 


13.2 Thermal Characteristics 


Characteristic Symbol Value Unit 


Thermal Resistance : 
Plastic 0 JA 60 C/W 
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13.3 DC Electrical Characteristics 


(Vpp = 5.0 VdC +10%, Vgg = 0Vdc, Ta = 0°C to +70°C, unless otherwise noted) 


Characteristic Symbol Min Typ Max Unit 
Output High Voltage (|| 54g = -5-0 mA) 
PAO-PA7, PBO-PB1, PC2-PC7, PWM0-PWM7 Vou Vpp-0.8 — — Vv 


Output Low Voltage (I; 94g = 5.0 mA for +5V pins and 
lLoad = 10.0 mA for +12V open-drain pins) 
PAO-PA7, PBO-PB5, PCO-PC7, PDO-PD3, PWMO0- 


PWM7 VoL — — 0.5 Vv 


Input High Voltage 
PAO-PA7, PBO-PB5, PCO-PC7, PDO-PD1, RESET, 


IRQ, EXTAL Vin 0.8 x Vpp — Vpp V 
(TTL Level) VSYNC, HSYNC, SOG Vin 2.0 —_— Vpp Vv 
SDA,SCL Vin 0.8 XVpp = Vpp V 


Input Low Voltage 
PAO-PA7, PBO-PB5, PCO-PC7, PDO-PD3, RESET, 


TRQ, EXTAL Vgs — 0.2xVpp | V 
ViL 
(TTL Level) VSYNC, HSYNC, SOG Vss = 0.8 Vv 
SDA,SCL Vsg — 0.2xVpp | V 
Supply Current (see Notes) 
Run Ipp — 8 20 mA 
Wait lbp — 4 8 mA 
I/O Ports Hi-Z Leakage Current 
PAO-PA7, PBO-PB5, PCO-PC7, PDO-PD3 loz _ —_— 10 LA 
Input Current 
RESET, IRQ, EXTAL, VSYNC, HSYNC lIN — — 1 HA 
Capacitance 
Ports (as Input or Output), RESET, IRQ, EXTAL, XTAL Cout = = 12 pF 
HSYNC, VSYNC Cin — — 8 pF 
NOTES: 


1. All values shown reflect average measurements. 

2. Typical values at midpoint of voltage range, 25°C only. 

3. Wait Ipp: Only timer system and SSP active. 

4. Run (Operating) Ipp, Wait Ipp: Measured using external square wave clock source to EXTAL (fggc = 4.2 MHz), 
all inputs 0.2 VDC from rail; no DC loads, less than 50pF on all outputs, CL = 20 pF on EXTAL. 

. Wait Ipp: All ports configured as inputs, Vy = 0.2 VDC, Vj = Vpp-0.2 VDC. 

6. Wait lpp is affected linearly by the EXTAL capacitance. 


oa 
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13.4 Control Timing 


(Vpp = 5.0 VdC +10%, Vgg = 0Vdc, Ta = 0°C to +70°C, unless otherwise noted) 


Characteristic Symbol Min Max Units 

Frequency of Operation 

Crystal Oscillator Option fosc — 4.2 MHz 

External Clock Source fosc de 4.2 MHz 
Internal Operating Frequency 

Crystal Oscillator (fogc/2) fop = 2.1 MHz 

External Clock (fosc¢/2) fop de 2.1 MHz 
Cycle Time (1/fop) tcyc 480 _ ns 
Crystal Oscillator Start-up Time (Crystal Oscillator option) toxoNn — 100 ms 
RESET Pulse Width Low tRL 1.5 a tcyc 
IRQ Interrupt Pulse Width Low (Edge-Triggered) tH 125 = ns 
IRQ Interrupt Pulse Period tL note 1 — tcyc 
EXTAL Pulse Width ton, tot 100 —= ns 

NOTE: 
1. The minimum period t, |, should not be less than the number of cycles it takes to execute the interrupt service routine plus 21 
'cyc- 
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13.5 DDC12AB TIMING 
(Vpp = 5.0 VdC +10%, Vgg = 0Vdc, Ta = 0°C to +70°C, unless otherwise noted 


13.5.1 DDC12AB Interface Input Signal Timing 


Parameter Symbol Min Max Units 
START condition hold time tuD.STA 2 — tcyc 
Clock low period tlow 4 — tcyc 
Clock high period tHIGH 4 = tcyc 
Data set up time tsu.DAT 250 = ns 
Data hold time tuD.DAT 0 — ns 
START condition set up time (for repeated START condition only) | tsyu.sta 2 — tcyc 
STOP condition set up time tsu.sTo 2 — tcyc 


13.5.2 | DDC12AB Interface Output Signal Timing 


Parameter Symbol Min Max Units 
SDA / SCL rise time (see NOTE 1) tr — 1.0 Us 
SDA / SCL fall time (see NOTE 1) tt | — | 300 ns 
Data set up time tsu.DAT tlow — ns 
Data hold time tuD.DAT 0 = ns 


OTE: 
1. With 200 pF loading on the SDA/SCL pins 


_ an oe 


SCL 
SE Ch ac hence ie <—> 
tup.sta ‘Low tHIGH  tsU.DAT tHD.DAT tsU.STA tsu.sTO 
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13.6 HSYNC/VSYNC Input Timing 


(Vpp = 5.0 Vdc +10%, Vgg = 0 VDC, Ta = 0°C to +70°C, unless otherwise noted) 


Parameter Symbol Min Max Units 
VSYNC input sync pulse tvi.Sp 1/2 4096 tcyc 
HSYNC input sync pulse tu.spP 1/2 12 tcyc 
VSYNC to VSYNO delay (8pF loading) tvvd 30 40 ns 
HSYNC to HSYNO delay (8pF loading) tuHd 30 40 ns 
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SECTION 14 MECHANICAL SPECIFICATIONS 


14.1.‘ Introduction 
The MC68HCO5BD7 is available in 40-pin DIP and 42-pin SDIP packages. 


14.2  40-Pin DIP Package (Case 711-03) 


NOTES: 

1. POSITIONAL TOLERANCE OF LEADS (D), SHALL 
BE WITHIN 0.25 mm (0.010) AT MAXIMUM 
MATERIAL CONDITION, IN RELATION TO SEATING 
PLANE AND EACH OTHER. 

2. DIMENSION LTO CENTER OF LEADS WHEN 
FORMED PARALLEL. 

3. DIMENSION B DOES NOT INCLUDE MOLD FLASH. 


MILLIMETERS INCHES 
MIN MAX MIN | MAX 
51.69 | 52.45 | 2.035 | 2.065 
13.72 | 14.22 | 0.540 | 0.560 
3.94 5.08 | 0.155 | 0.200 
0.36 0.56 | 0.014 | 0.022 
1.02 1.52 | 0.040 | 0.060 

54 BSC 0.100 BSC 
1.65 2.16 | 0.065 | 0.085 
0.20 0.38 | 0.008 | 0.015 


o 
= 


SEATING 
PLANE 


2|=/- |x| C/T O|molo|a\> 
id 
ial 
> 


14.3. 42-Pin SDIP Package (Case 858-01) 


NOTES: 

. DIMENSIONS AND TOLERANCING PER ANSI 
Y14.5M, 1982. 

CONTROLLING DIMENSION: INCH. 
DIMENSION L TO CENTER OF LEAD WHEN 
FORMED PARALLEL. 
. DIMENSIONS A AND B DO NOT INCLUDE MOLD 
FLASH. MAXIMUM MOLD FLASH 0.25 (0.010). 


INCHES MILLIMETERS 
MIN MAX | MIN | MAX 
1.435 | 1.465 | 36.45 | 37.21 
0.540 | 0.560 | 13.72 | 14.22 
0.155 | 0.200 | 3.94 | 5.08 
0.014 | 0.022 | 0.36 | 0.56 
0.032 | 0.046 | 0.81 1.17 
0.070 BSC 1.778 BSC 
0.300 BSC 7.62 BSC 
0.008 | 0.015 | 0.20 | 0.38 
0.115 | 0.135 | 2.92 | 3.43 
0.600 BSC 15.24 BSC 
0° 15° 0° 15° 
0.020 | 0.040 | 0.51 1.02 


er 


S 


| 


2ZE|r | zA\e/ Tl On o\o|a|> 


il 
5, A 
SEATING i 
PLANE |. m i = 
D42PL K J 42 PL} <— ~~ 


| 0.25 (0.010) ® |T| A® 1 0.25 (0.010) ® |T| B© 
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SECTION 15 APPLICATION DIAGRAM 


me Ju | lu | lu lu jlu {lu [lu jiu [lu [lu jiu flu 
MC68HC05BD7 : 
LU pwe— VSYN a ihe PC 
2\pwmis*  HSYNC 40 10K O 
PWMO0** PWM3**73 0 \M e 
tH RESET Cr RESET — PWMa*S xc 
==+— | vpp PwMS**3 7 a ec 
—— oe Sl so CLAMP3E ae 
L vss PWM6** 
“rT 8 PwM7#42> ik 
In| g| XTAL 34 \/ 
sof 1 — 10 EXTAL HSYNO}33 ale. +. 
4MHz_— PBS* VSYNO}35—T0K “eos . 
pS 11 PB4* PWM1 ie Cc 
Wwp~< 12 PB3* PWM1 
een 13 PB2* ADC] 
EEPROM 2% a App ADC 
osp *— ie PBO PWM9 x 
Ss TRO PWMS8 
17 paz SCL 
18) pa6 SDA 
— PAS PA 
20 PAA PAI~2—_ 
zp zg 2llpas a 
Se fe i : ai 
aya 


*Note: RESET IC is MC34064 
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